美文网首页
React路由

React路由

作者: 橙赎 | 来源:发表于2020-04-10 15:53 被阅读0次

React 路由

一、在React中使用react-router-dom路由
  • 安装

    npm install react-router-dom --save-dev //这里可以使用cnpm代替npm命令
    
  • 引入

    import { BrowserRouter as Router, Route, Switch, NavLink, Redirect } from 'react-router-dom';
    
    • BrowserRouter :H5提供的的 history 模式,我们称之为 BrowserRouter

    • Route:Route代表了你的路由界面,path代表路径,component代表路径所对应的界面

    • Router:Router我们可以把它看做是react路由的一个路由外层盒子,它里面的内容就是我们单页面应用的路由以及路由组件

    • Switch:表示只渲染一个路径

    • NavLink:会在匹配上当前的url的时候给已经渲染的元素添加参数

    • Redirect:重定向

二、使用
  • 申明式导航
<Router>
      <div className='manager-center'>
        <div className='title'>管理中心</div>
        <div className='base'>
          <div className='caidan'>
            <NavLink to='/list'>列表</NavLink>
            <div className='user-base'>
              <NavLink to='/user'>用户</NavLink>
              <div>
                <NavLink to='/user/register'>注册</NavLink>
              </div>
            </div>
          </div>
          <div className='content'>
            <Switch>
              //exact精准匹配
              <Route exact path='/list' component={List}></Route>
              <Route path='/user' component={User}></Route>
            </Switch>
          </div>
        </div>
      </div>
    </Router>
  • 编程式导航
 this.props.history.push('/index'); 
三、动态路由传参
  • 动态路由传参: 通过match.params获取参数
路由页面:<Route path='/demo/:id' component={Demo}></Route>  //注意要配置 /:id
路由跳转并传递参数:
    链接方式:<Link to={'/demo/'+'6'}>XX</Link>
        或:<Link to={{pathname:'/demo/'+'6'}}>XX</Link>

    js方式:this.props.history.push('/demo/'+'6')  
        或:this.props.history.push({pathname:'/demo/'+'6'})
获取参数:this.props.match.params.id    //注意这里是match而非history
  • params传参(多个动态参数)
state={
    id:88,
    name:'Jack',
}
路由页面:<Route path='/demo/:id/:name' component={Demo}></Route>  
路由跳转并传递参数:
    链接方式:<Link to={{pathname:`/demo/${this.state.id}/${this.state.name}`}}>XX</Link>

    js方式:this.props.history.push({pathname:`/demo/${this.state.id}/${this.state.name}`})
获取参数:this.props.match.params     //结果 {id: "88", name: "Jack"}
  • query传参(刷新页面后参数消失)
路由页面:<Route path='/demo' component={Demo}></Route>  //无需配置
路由跳转并传递参数:
    链接方式:<Link to={{pathname:'/demo',query:{id:22,name:'dahuang'}}}>XX</Link>
    js方式:this.props.history.push({pathname:'/demo',query:{id:22,name:'dahuang'}})
获取参数: this.props.location.query.name
  • state传参( 刷新页面后参数不消失,state传的参数是加密的,比query传参好用)
路由页面:<Route path='/demo' component={Demo}></Route>  //无需配置
路由跳转并传递参数:
    链接方式: <Link to={{pathname:'/demo',state:{id:12,name:'dahuang'}}}>XX</Link> 
    js方式:this.props.history.push({pathname:'/demo',state:{id:12,name:'dahuang'}})
获取参数: this.props.location.state.name

相关文章

  • react从0到1的探索记录04

    18、React中的路由 React中路由的基本使用 在react中使用路由首先需要安装react的路由模块 np...

  • react学习资料八

    路由 使用react的路由就要引入react路由插件react-router.js ReactRouter 保存一...

  • React-Router知识点

    路由的分类 页面路由 hash 路由 h5路由 react路由 react-router-dom 路由方式 h5路...

  • React路由

    React 路由 一、在React中使用react-router-dom路由 安装npm install reac...

  • 有标题的文章

    React Redux 路由设计 - - React

  • React路由

    React路由 一、路由的形式 hash路由 : HashRouter history路由 : BrowserRo...

  • react-router Q & A

    什么是React 路由? React 路由是一个构建在 React 之上的强大的路由库,它可以让你向应用中快速地添...

  • 2018-12-21路由

    1.路由 React路由依赖于React Router,React Router保持UI和与URL的同步。它拥有简...

  • react-router-dom 的基本使用

    本文介绍 react 中路由的使用。在 react 中使用 路由的库为 react-router。或者是 reac...

  • react-router

    React Router 是完整的 React 路由解决方案 import React from 'react' ...

网友评论

      本文标题:React路由

      本文链接:https://www.haomeiwen.com/subject/uoirmhtx.html