zoukankan      html  css  js  c++  java
  • React-router

    React-router
    市场上的react-router的版本有1、2、3、4,1-3的差别不大,使用于16.0.0以下的版本
    react-router 4.0 适用于16.0.0以上
    在这里使用15.6.1的react。这个版本的react允许使用React.createClass来创建组件,在16以上只能使用class类的方式来创建
    1. 渲染根组件的时候,最外层包裹上Router组件,在其上可以设置history属性,值可以是hashHistory||browserHistory
    当值为hashHistory的时候,url的变化为hash值的变化,router会去检测hash变化来实现组件的切换
     
    当值为browserHistory的时候,url的变化为path的变化,需要后端进行配置
    2. Router中使用Route组件来描述每一级路由,Route上有path、component属性,代表着当path改变成...的时候,就渲染..组件
    3. 在需要切换路由组件的地方,通过this.props.children来表示对应路由组件
    4. 在Route中可以多次嵌套Route来实现多级路由
    ```
    <Route path="news" component={News}>
    //二级路由
    <IndexRedirect to="Inside"/>
    <Router path="outside" component={Outside} onLeave={()=>{
    console.log(arguments)}}/>
    <Router path="Inside" component={Inside}/>
    </Route>
    ```
    5. IndexRoute可以设置该路由中的默认子路由
    <IndexRoute component={Home}/>
    ```
    <Route path="news" component={News}>
    //二级路由
    <IndexRedirect to="Inside"/>
    <Router path="outside" component={Outside} onLeave={()=>{
    console.log(arguments)}}/>
    <Router path="Inside" component={Inside}/>
    </Route>
    ```
    6. IndexRedirect可以设置在进入该路由之后马上跳转到哪里
    <IndexRedirect to='home'/>
    7. 使用Redirect组件可以做到从一个路由马上重定向到其他路由,利用这样的属性,当我们form设置为'*'的时候,就可以将匹配不到的路由重定向到某げ路由下
    <Redirect from="*" to="home"/>
    8. 可以在配置Route的时候给path里加入/:param 才表示此路由需要参数
    传入的时候,querystring参数可以在Link里的query中传入和设置,在目标组件中,通过this.props中的,params、routePrams、location等来接收参数
    在组件中console.log(this)可以打印出挂在的数据
    ```
    <Route path="detail/:id" component={Detail}/>
    <Link query={{text:item.text}} to={`/detail/${item.id}`}>{item.text}</Link>
    ```
    9. 可以通过过Router传入routes参数,值为数组,来设置路由配置:
    ```
    const routeConfig = [
    { path: '/',
    component: App,
    indexRoute: { component: Home },
    childRoutes: [
    { path: 'home', component: Home },
    { path: 'news',
    component: News,
    childRoutes: [
    { path: 'inside', component: Inside },
    { path: 'outside',component:Outside}
    ]
    },
    { path: 'detail/:id', component: Detail },
    {path:'*',component:Home}
    ]
    }
    ]
    
    
    ReactDOM.render(
        
        <Router routes={routeConfig} history={hashHistory}></Router>
        ,document.getElementById('app'))
    
    
    ```
    10. 编程式导航
    * 在路由组件中通过this.props.history获取到history对象,利用里面push、replace、go、goBack方法来进行隐式跳转
    * 可以从react-router中引入browserHistory或者hashHistory调用里面的push、replace、go、goBack方法来进行隐式跳转
    11. 可以通过在路由配置上设置 onLeave和onEnter路由钩子来监听路由的变化
    12. 给路由添加样式;使用activeClassName或者activeStyle
    ```
    <Link activeClassName = {'active'} to={item.path} key={item.id}>{item.text}</Link>
    ```
  • 相关阅读:
    递归和回溯_leetcode-floodfill
    递归和回溯_leetcode131
    递归和回溯_leetcode130
    递归和回溯_leetcode93-经典的回溯题
    递归和回溯_leetcode90
    递归和回溯_leetcode79
    递归和回溯_leetcode78-经典的子集
    知识树杂谈(1)
    Android 设备兼容性(1)
    微信小程序- 生成二维码
  • 原文地址:https://www.cnblogs.com/naniandongzhi/p/8298744.html
Copyright © 2011-2022 走看看