IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> react路由使用方式 -> 正文阅读

[JavaScript知识库]react路由使用方式

一、react路由的基本使用
1、明确好界面中的导航区,展示区。
2、导航区的a标签改为Link标签
<Link to="/xxxxx"/></Link>
3、展示区写Router标签进行路经匹配
<Router path="/xxxx" component={Demo} />
4<App>的最外侧包裹了一个<BrowserRouter>或者<HashRouter>

二、路由组件与一般组件的区别
1、写法不同:
一般组件:<Demo/>
路由组件:<Router path="/demo" component={Demo} />
2、存放位置不同
一般组件:components
路由组件:pages views
3、接收到的props不同
一般组件:写组件标签是传递了什么,就能收到什么
路由组件:接收到三个固定的属性
history:
	go
	goBack
	goForward
	push
	replace
location:
	pathname:"/about"
	search:""
	state:undefind
match:
	params:{}
	path:"/about"
	url:"/about"


三、NavLink与封装NavLink
	1、NavLink可以实现路由链接的高亮,通过activeClassName指定样式名
	2、标签体内容是一个特殊的标签属性
	3、通过this.props.children可以获取标签体内容
	
四、Switch的使用
1、通常情况下,path和component是一一对应的关系
2、Switch可以提高路由匹配效率(单一匹配)Switch只显示匹配到的第一个路由
五、解决多级路经刷新页面样式丢失问题
1public/index.html 中 引入样式时不写.//(常用)
2public/index.html中 引入样式时不写./%PUBLIC_URL%(常用) react才有
3、使用HashRouter

五、路由的严格匹配与模糊匹配
1、默认使用的是模糊匹配(简单记:【输入的路经】必须包含要【匹配的路经】,且顺序要一致)
2、开启严格匹配:<Router exact={true} path="/about" component={About} />
3、严格匹配不要随便开启,需要再开,有些时候开启会导致无法继续匹配二级路由

六、Redirect的使用
1、一般写在所有路由注册的最下方,当所有路由都无法匹配时,跳转到Redirect指定的路由
2、具体编码:


<Switch>
<Router path="/about" component={About} />
<Route path="/home" componet={Home} />
<Redirect to="/about" />
<Switch />

七、嵌套路由
1、注册子路由时要写上父路由的path值
2、路由的匹配是按照注册路由的顺序进行的

八、向路由组件传递参数
1、params参数
路由链接(携带参数): 详情
注册路由(声明接收): component={Test} />
接收参数:this.props.match.params
2、search参数
路由链接(携带参数):详情
注册路由(无需声明,正常注册即可)
接收参数:this.props.location.search
备注:获取到的search是urlencoded编码字符串,需要借助querystring解析
3、state参数
路由链接(携带参数):<Link to={{path:"/demo/test",statr:{name:‘tom’,age:18}}}>详情
注册路由(无需声明,正常注册即可)
接收参数:this.props.location.state
备注:刷新也可以保留住参数

九、编程式导航跳转
借助this.props.history对象上的Api对操作路由跳转、前进、后退
this.props.history.push(’/home/message’) 有历史栈
this.props.history.replace(’/home/message’) 替换当前栈顶的路由
this.props.history.goBack()
this.props.history.goGorward()
this.props.history.go() 前进和后退

十、withRouter
withRouter可以加工一般组件,让一般组件具备路由组件所特有的api
withRouter的返回值是一个新组件

十一、BrowserRouter与HashRouter的区别
1、底层原理不一样:
BrowserRouter使用的是h5的historyAPI不兼容IE9及以下版本。
HashRouter使用的是URL的哈希值。
2、path表现形式不一样
BrowserRouter的路经中没有#,例如:localhost:3000/demo/test
HashRouter的路经包含#,例如localhost:3000/#/demo/test
3、刷新后对路由state参数的影响
(1).BrowserRouter没有任何影响,因为state保存在history对象中。
(2).HashRouter刷新后会导致路由state参数的丢失。
4、备注:HashRouter可以用于解决一些路经错误相关的问题。

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-08-17 15:18:45  更:2021-08-17 15:21:02 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年12日历 -2024/12/26 17:34:54-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码
数据统计