React 路由
1、安装
cnpm install react-router-dom -S
2、引入react-router-dom 选择路由的形式
HashRouter:路由的根组件 也是路由的一种形式(hash路由) 带#号
BrowserRouter:路由的根组件 也是路由的一种形式(history路由) 不带#号
所有路由的配置项都必须在路由的根组件内部
data:image/s3,"s3://crabby-images/d694b/d694b7e057ee9697ec8e4a11e1853c1a930e6a40" alt=""
3、引入Route
Route是路由渲染的方式
常用的属性:
path:路由的路径
component:需要渲染的组件 值是组件的名称
render:需要渲染的组件 值是组件
exact:完全匹配
data:image/s3,"s3://crabby-images/156ae/156ae2da658e28e0f3b9e0d0c66edc662fb8d9dc" alt=""
4、路由跳转的方式
A、a标签
B、link
C、NavLink
D、编程式导航
data:image/s3,"s3://crabby-images/48bfc/48bfc412023bf62d21b28dd6c8fc8ec066594982" alt=""
Link && NavLink区别?
前者没有选中的标识 后者会有选中的标识
场景:前者非TabBar 后者TabBar
属性:
activeClassName: 设置选中后的类名
activeStyle:设置选中后的状态
5、路由重定向:
Redirect:路由重定向
属性:
from:从哪里来
to:到哪里去
exact:完全匹配
建议最外层加上switch
6、Switch
Switch是一个组件 作用是只匹配一个路由
data:image/s3,"s3://crabby-images/e886a/e886a1e6bab21b3d69a7205b8c75648d92033eed" alt=""
7、路由嵌套:
1、
通过render的方式进行嵌套
2、
将嵌套的内容放在Switch的外面。
data:image/s3,"s3://crabby-images/11ca5/11ca5cbb4badcd676ddb84b07597898f49309d88" alt=""
8、路由传参:
动态路由(最多)
A、在定义路由的时候通过/:属性的方式来定义传递参数的属性
data:image/s3,"s3://crabby-images/e61d8/e61d8b8fb5fa5ecb0af5319b7e748cbe4c927d9b" alt=""
B、在路由跳转的时候传递需要传递的数据
data:image/s3,"s3://crabby-images/6253a/6253a4bec8cbd795bc2e136b225950d06b16d3e8" alt=""
C、接收: this.props.match.params
data:image/s3,"s3://crabby-images/efac6/efac676f640bcbfe37ba51a52cfe7e8936bffb03" alt=""
query传值(其次)
A、在路由跳转的时候通过地址拼接的方式进行数据的传递(类似于get传值的方式)
data:image/s3,"s3://crabby-images/f66ef/f66ef5c92c0ecf81df0a76af48f07ad6d4d5e5ee" alt=""
B、接收的时候通过this.props.location.search 进行接收 (注意需要url模块的解析)
data:image/s3,"s3://crabby-images/7abfc/7abfc0de5023cb927570164337416fd39bf967c0" alt=""
对象传值
1、在路由跳转的时候通过对象的方式进行路由跳转
data:image/s3,"s3://crabby-images/bfcbf/bfcbff3e2456d359a2e2592eb62d5504dbe54a0c" alt=""
2、接收的时候通过this.props.location.query进行接收
注意:刷新浏览器数据会丢失(慎用)
编程式导航
this.props.history.push({pathname:"/detail",query:{id:item.id,name:item.name}})
component与render的区别
render
1、render可以渲染组件 以及标签
2、render的渲染方式可以进行组件传参
3、render的渲染方式可以进行逻辑判断
4、render的渲染方式可以进行路由嵌套
5、如果render需要路由的三个属性的情况下 需要手动传递
component:
1、只能渲染组件,因为component的值是组件的名称 而不是组件标签
2、component的值因为是组件名称所以不能传值,也不能做逻辑判断 以及路由嵌套
3、只要通过component渲染的组件那么这个组件的props身上就会多三个属性 history location match(优势)
编程式导航:
this.props.history.goBack()
this.props.history.push()
this.props.history.goForward()
this.props.history.replace()