详解前端路由实现与react-router使用姿势
路由
对于有过SPA开发经验的人来说,路由这个名词并不陌生,前端的路由和后端的路由在实现技术上不一样,但是原理都是一样的。在HTML5的historyAPI出现之前,前端的路由都是通过hash来实现的,hash能兼容低版本的浏览器。它的URI规则中需要带上#。Web服务并不会解析hash,也就是说#后的内容Web服务都会自动忽略,但是JavaScript是可以通过window.location.hash读取到的,读取到路径加以解析之后就可以响应不同路径的逻辑处理。
简单介绍AngularJsUI-Router路由
如果你有过AngularJS开发经验,#并不陌生,angularjs有自己官方实现的路由体系,也有比较具有代表性的第三方嵌套路由机制UI-Router;如下代码块所示:
.state("main.list",angularAMD.route({ url:'/list/:params',//url&参数 views:{ "header@main":angularAMD.route({ templateUrl:'simple/view/main/html/main/Header.html', controller:'HeadController', controllerUrl:[****.js ] }), "menu@main":angularAMD.route({ templateUrl:'simple/view/main/html/main/MenuModule.html', controller:"MenuController", controllerUrl:[****.js] }), "mainContent@main":angularAMD.route({ templateUrl:'simple/view/main/html/main/MainContent.html' }) } }))
state()函数的第一个参数就是路由,“main.list”是一个嵌套路由机制,当页面跳转到“main.list”路由下时会先加载state(“main”,*)下的模块及其资源(html,js等),随后加载state(”main.list”)下的模块和资源(html,js等),实现路由嵌套;
react-router
-先上一段代码
React-router以jsx语法类似于DOM结构的形式实现router嵌套;与AngularJs的UI-Router看似差别很大,实则思想雷同;
Angular的实现逻辑:
跳转=》state=》module=》静态资源(js,css,html)=》show(页面展示)
react-router的实现逻辑:
跳转=》path=》component=》静态资源(js,css,html)=》show(页面展示)
本文主要讲react-router,下面简单介绍react-router的使用姿势:
react-router常用组件入门
嵌套路由
上面代码中,用户访问/repos时,会先加载App组件,然后在它的内部再加载Repos组件。
子路由也可以不写在Router组件里面,单独传入Router组件的routes属性
letroutes=;
path属性
Route组件的path属性指定路由的匹配规则,看下面例子
上面代码中,当用户访问/inbox/messages/:id时,会加载下面的组件。
IndexRoute组件
类似index.html,默认加载组件,下面代码默认加载home组件
现在,用户访问/的时候,加载的组件结构如下。
Redirect组件
Redirect组件用于路由的跳转,即用户访问一个路由,会自动跳转到另一个路由。
{/*从/inbox/messages/:id跳转到/messages/:id*/} <Redirectfrom="messages/:id"to="/messages/:id"/>
现在访问/inbox/messages/5,会自动跳转到/messages/5。
Link
Link组件用于取代a标签,生成一个链接,允许用户点击后跳转到另一个路由。它基本上就是a标签的React版本,可以接收Router的状态。
表单处理
Link组件用于正常的用户点击跳转,但是有时还需要表单跳转、点击按钮跳转等操作。这些情况怎么跟ReactRouter对接呢?
第一种方法是使用browserHistory.push
handleSubmit(event){ event.preventDefault() constuserName=event.target.elements[0].value constrepo=event.target.elements[1].value constpath=`/repos/${userName}/${repo}` browserHistory.push(path) }
${userName}一种后端语言常用的表达式写法,可在字符串中取变量
handleSubmit(event){ //... this.context.router.push(path) },
第二种方法是使用context对象。
exportdefaultReact.createClass({ //askfor`router`fromcontext contextTypes:{ router:React.PropTypes.object }, handleSubmit(event){ //... this.context.router.push(path) }, })
多人协作开发router文件管理
一般一个项目都会有一个统一的router文件,相当于一个router池,不同的请求,请求router池中所匹配的路径,加载请求所需页面。but。。。每个开发者开发一个组件都会需要配置路由,会导致router文件不易管理,容易导致冲突,甚至故障。so。。,也许,可能可以每个组件文件夹下对于一个XXX.router文件,前端代码打包上传到线上时触发某个钩子函数,将XXX.router文件统一合并到中央router文件中,从而避免多人操作router文件。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。