关于react router 4 的小实践

详细代码栗子:https://github.com/wayaha/react-dom-CY

clone然后

npm install
npm start

分割线



1、这个项目使用create-react-app搭建;

  首先需要安装好create-react-app

npm install -g create-react-app

  安装完毕之后就是搭建项目;

create-react-app your-project-name
cd your-project-name
npm start

  安装完成之后,会自动打开localhost:3000;打开create-react-app自带的一个简单dom。

  **  另外,create-react-app默认配置样式使用的.css文件,习惯使用.scss的大佬可以在config文件下的 webpack.config.dev.js 和 webpack.config.prod.js 中rules数组中添加下面配置即可;

{
    test:/\.scss$/,
    loaders:[‘style-loader‘, ‘css-loader‘, ‘sass-loader‘]
}

2、关于相关安装包的下载

  React Router被拆分成三个包:react-router,react-router-domreact-router-nativereact-router提供核心的路由组件与函数。其余两个则提供运行环境(即浏览器与react-native)所需的特定组件。

  进行网站(将会运行在浏览器环境中)构建,我们应当安装react-router-domreact-router-dom暴露出react-router中暴露的对象与方法,因此你只需要安装并引用react-router-dom即可。

npm install --save react-router-dom

3、开始项目代码

  代码结构如下:

 

  (1)、路由类型的选择

    在你开始项目前,你需要决定你使用的路由的类型。对于网页项目,存在<BrowserRouter><HashRouter>两种组件。当存在服务区来管理动态请求时,需要使用<BrowserRouter>组件,而<HashRouter>被用于静态网站。

    通常,我们更倾向选择<BrowserRouter>,但如果你的网站仅用来呈现静态文件,那么<HashRouter>将会是一个好选择。

    从效果上来看,<BrowserRouter><HashRouter>在url中少了一个#,需要注意的是,没有#的路由切换前后对服务端来说是不同的url,。在我们的Dome中可以试一下,代码在index.js如下:

import React from ‘react‘;
import ReactDOM from ‘react-dom‘;
import { createStore } from ‘redux‘;
import {
    // BrowserRouter,
    HashRouter
} from ‘react-router-dom‘;
import { Provider } from ‘react-redux‘;
import reducer from ‘./redux‘;
import ‘./index.css‘;
import App from ‘./App‘;
import registerServiceWorker from ‘./registerServiceWorker‘;

const store = createStore(reducer);

ReactDOM.render(
    <Provider store={store}>
        {/* <BrowserRouter> */}
        <HashRouter>
            <App />
        </HashRouter>
        {/* </BrowserRouter> */}
    </Provider>,
    document.getElementById(‘root‘)
);
registerServiceWorker();

  (2)、一级路由就是Route文件下的index.js文件所示;

    代码如下:

import React, { Component } from ‘react‘;
import { Switch, Route, Redirect, NavLink } from ‘react-router-dom‘;
import Home from ‘../components/Home‘;
import Company from ‘../components/Company‘;
import Park from ‘../components/Park‘;
import ‘./index.scss‘;

class Main extends Component {
    // constructor (props) {
    //     super(props);
    // };
    componentDidMount () {
        console.log(‘this is Main...‘);
    };

    render () {
        return (
            <main className={‘mainSec‘}>
                <nav>
                    <NavLink className="resetNavLink" activeClassName=‘navActive‘ to=‘/home‘>{‘Home‘}</NavLink>&nbsp; 
                    <NavLink className="resetNavLink" activeClassName=‘navActive‘ to=‘/company‘>{‘Company‘}</NavLink>&nbsp; 
                    <NavLink className="resetNavLink" activeClassName=‘navActive‘ to=‘/park‘>{‘park‘}</NavLink>
                </nav>
                <Switch>
                    <Route exact path=‘/home‘ component={Home} />
                    <Route path=‘/company‘ component={Company} />
                    <Route exact path=‘/park‘ component={Park} />
                    <Redirect to=‘/home‘ />
                </Switch>
            </main>
        )
    }
};

export default Main;

    a、锚点的选择和使用

      现在,我们应用需要在各个页面间切换。如果使用锚点元素(就是)实现,在每次点击时页面将被重新加载。React Router提供了<Link>和<NavLink>组件用来避免这种状况的发生。当你点击<Link>时,URL会更新,组件会被重新渲染,但是页面不会重新加载。实际上锚点元素就是一个a标签,to属性就相当于href属性;

      <Link>使用‘to‘参数来描述需要定位的页面。它的值也可以是location对象(包含pathname,search,hash与state属性)。如果其值为字符床将会被转换为location对象。

      <NavLink>可以增加 activeClassName 或者 activeStyle 属性,设置当前路由被选中的样式;

         -- exact:  当为true时,仅当位置匹配完全时才会应用活动类/样式。

    b、Route

      path: string; 一个有效的URL路径。

      exact: bool  当为true时,仅当路径与location.pathname完全匹配时才匹配。如果该路由有子路由,不能设置为true。

      strict: bool  当为true时,具有尾部斜杠的路径将仅与具有尾部斜杠的location.pathname匹配。当在location.pathname中有其他URL段时,这不起作用。strict可以用来强制执行location.pathname没有尾部斜杠,但为了做到这一点,strict和exact必须是true。

      另外,还有component、render 和 children属性,这三个属性优先级依次降低,不可以在一个Route组件上使用这三个属性中的多个。一般选择用component属性。

    c、Redirect 重定向

      to: string/Object   要重定向到的网址。

      push: bool 当为true时,重定向会将新条目推入历史记录,而不是替换当前条目。

      from: string  要重定向的路径名。这只能用于在<Switch>内部呈现<Redirect>时匹配位置;

    d、Switch 它的独特之处是独它仅仅渲染一个路由;

  (3)、路由的嵌套

    路由嵌套在Companey组件中;代码如下;

import React, { Component } from ‘react‘;
import { Switch, Route, NavLink, Redirect } from ‘react-router-dom‘;
import FontEnd from ‘./FontEnd‘;
import BackEnd from ‘./BackEnd‘;
import Test from ‘./Test‘;
import Manage from ‘./Manage‘;

class Company extends Component {
    componentDidMount () {
        console.log(‘this is Company...‘);
    };

    render () {
        const { match } = this.props;
        // console.log(match);
        return (
            <div>
                <p>{‘this is Company.....‘}</p>
                <nav>
                    <NavLink className="resetNavLink" activeClassName=‘navActive‘ to=‘/company/fontEnd‘>{‘FontEnd‘}</NavLink>&nbsp; 
                    <NavLink className="resetNavLink" activeClassName=‘navActive‘ to=‘/company/backEnd‘>{‘BackEnd‘}</NavLink>&nbsp; 
                    <NavLink className="resetNavLink" activeClassName=‘navActive‘ to=‘/company/test‘>{‘Test‘}</NavLink>&nbsp; 
                    <NavLink className="resetNavLink" activeClassName=‘navActive‘ to=‘/company/manager‘>{‘Manager‘}</NavLink>
                </nav>
                <Switch>
                    <Route exact path={`${match.path}/:department`} render={(localtions) => {
                            const { match: { params: {department} }} = localtions;
                            console.log(department);
                            const temp = {fontEnd: <FontEnd />, backEnd: <BackEnd />, test: <Test />, manager: <Manage />}
                            return temp[department];
                        }}
                    />
                    <Redirect to=‘company/fontEnd/‘ />
                </Switch>
            </div>
        );
    };
};

export default Company;

    这个没有什么特别的,需要注意的就是,子路由Route的path和锚点的 to 都是需要一个完整的路由路径; 子路由路径中 ”:“ 后的属性是可传到子组件的参数,在子组件this.props.match.params中是可以拿到的。

原文地址:https://www.cnblogs.com/this-day/p/9012620.html

时间: 2024-08-04 19:42:50

关于react router 4 的小实践的相关文章

Redux+React Router+Node.js全栈开发

详情请交流  QQ  709639943 01.Java深入微服务原理改造房产销售平台 02.跨平台混编框架 MUI 仿豆瓣电影 APP 03.Node.js入门到企业Web开发中的应用 04.Redux+React Router+Node.js全栈开发 05.Java秒杀系统方案优化 高性能高并发实战 06.企业级刚需Nginx入门,全面掌握Nginx配置+快速搭建高可用架构 07.快速上手Linux 玩转典型应用 08.全面系统讲解CSS 工作应用+面试一步搞定 09.Java Spring

React漫漫学习路之 React Router

React Router 是一个基于 React 之上的强大路由库,它可以让你向应用中快速地添加视图和数据流,同时保持页面与 URL 间的同步. 目前react-router最新版本已经到4.0+,因为新的版本是一次非常大的改动,所以这里直接讨论4.0以上版本. 引用 react-router // React Router 核心 react-router-dom // 用于 DOM 绑定的 React Router react-router-native // 用于 React Native

react router 4.0以上的路由应用

thead>tr>th{padding:8px;line-height:1.4285714;border-top:1px solid #ddd}.table>thead>tr>td,.table>tbody>tr>th,.table>tbody>tr>td,.table>tfoot>tr>th,.table>tfoot>tr>td{padding:8px;line-height:1.4285714;ver

Native VS React Native VS 微信小程序

随着React Native和 微信小程序的出现,Native一家独大的局面出现裂痕,很多小公司使用已经正在着手微信小程序和React Native了,我公司就已经走上React Native之路.那么,React Native 和 Native 和 微信小程序 三者比较起来到底哪者更强呢?今天从适应性(适合什么项目).开发限制.软件迭代更新.成本角度谈谈自己对三者的看法. 个人角度: 适应性(适应什么项目) 大项目.游戏项目:Native 中大型项目:react native 小项目:微信小程

最新的chart 聊天功能( webpack2 + react + router + redux + scss + nodejs + express + mysql + es6/7)

请表明转载链接:http://www.cnblogs.com/zhangkunweb/p/6853728.html 我是一个喜欢捣腾的人,没事总喜欢学点新东西,可能现在用不到,但是不保证下一刻用不到. 我一直从事的是依赖angular.js 的web开发,但是我怎么能一直用它呢?看看最近火的一塌糊涂的reactjs ,我的天啊,不学会它,怎么能睡好觉. 今天我分享一个依赖最新版本的webpack + react + router + redux + scss + nodejs + mysql +

[React Router v4] Use the React Router v4 Link Component for Navigation Between Routes

If you’ve created several Routes within your application, you will also want to be able to navigate between them. React Router supplies a Link component that you will use to make this happen. Import Link: import { BrowserRouter as Router, Route, Link

[React Router V4] Create Basic Routes with the React Router v4 BrowserRouter

React Router 4 has several routers built in for different purposes. The primary one you will use for building web applications is the BrowserRouter. In this lesson you will import the BrowserRouter and create some basic Route components. After create

[Redux] Filtering Redux State with React Router Params

We will learn how adding React Router shifts the balance of responsibilities, and how the components can use both at the same time. Now when we click the filter, the url changes, but the todos list doesn't change. So continue with that. Router only r

[Redux] Navigating with React Router &lt;Link&gt;

We will learn how to change the address bar using a component from React Router. In Root.js: We need to add a param to change the Route: import React from 'react'; import {Provider} from 'react-redux'; import {Router, Route, browserHistory } from 're