首页 > 其他 > 详细

react--路由

时间:2019-06-11 20:49:34      阅读:114      评论:0      收藏:0      [点我收藏+]

1、路由的安装
cnpm install react-router-dom -S

2、路由的方式
HashRouter: 带hash值的router vue hash
BrowserRouter: 不带hash值的router vue history

注意:
1、路由的配置项必须在HashRouter、BrowserRouter内部做配置
2、HashRouter、BrowserRouter内部只能拥有一个子元素

3、路由配置项常用的组件


4、Route
作用:当路径匹配成功以后,渲染相对应的组件

属性:
path: 组件所对应的路径
component:需要渲染的组件 (组件渲染的方式)
render:需要渲染的组件 (组件渲染的方式)
exact:路径完全匹配

5、路由跳转的方式
1、link
2、NavLink

属性:
activeStyle
activeClassName

6、路由嵌套

7、路由渲染的方式
render:组件标签形式
1、不仅可以渲染组件 而且还可以渲染标签
2、 可以进行组件传值 以及逻辑判断
3、render渲染的组件默认是没有history location match 这三个属性的 如果需要使用 必须经过传递给组件
component:组价名称
1、只能渲染组件
2、凡是通过component进行组件渲染的 当前组件的props 中就有多三个属性(history location match)

 

8、路由传参

1、动态路由
在定义路由的时候,定义传递参数的key值 <Route path="/detail/:id/:name" component={Detail} />
在路由跳转的时候 传递需要传递的值 <h2 key={index}><Link to={item.path+"/"+item.goodsId+"/"+item.goodsName}>{item.goodsName}</Link></h2>

接收的时候通过this.props.match.params进行接收

2、query传值
1、根据query传值的方式进行路径的拼接 需要node中url模块的解析

2、根据对象的形式进行传值 to={{pathname:"路径",query:{需要传递的值}}}


9、编程式导航
this.props.history.goBack()
this.props.history.goForward()
this.props.history.push()
this.props.history.replace()


10、withRouter
1、当前组件如果内部的this.props中没有history location match的时候可以通过withRouter进行包裹组件
然后进行导出组件 这样当前组件就会有路由的这几个属性
import {withRouter} from "react-router-dom"
........
export default withRoute(组件名称)


11、Switch
被Switch包裹的路由组件 在匹配的时候只会匹配一个

12、Redirect
重定向
from:从哪里来
to:到哪里去

react--路由

原文:https://www.cnblogs.com/PeiGaGa/p/11005665.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!