一句话:实现URL与UI界面的同步。、
其中在react-router中,URL对应Location对象,
而UI是由react components来决定的,
这样就转变成location与components之间的同步问题。
react-router具体实现
react-router在history
库的基础上,实现了URL与UI的同步,分为两个层次来描述具体的实现。
3.1 组件层面描述实现过程
在react-router
中最主要的component
是Router
RouterContext
Link
,history
库起到了中间桥梁的作用。
3.2 API层面描述实现过程
为了简单说明,只描述使用browserHistory的实现,hashHistory的实现过程是类似的,就不在说明。
目前react-router
在项目中已有大量实践,其优点可以总结如下:
风格: 与React融为一体,专为react量身打造,编码风格与react保持一致,例如路由的配置可以通过component来实现
简单: 不需要手工维护路由state,使代码变得简单
强大: 强大的路由管理机制,体现在如下方面
路由配置: 可以通过组件、配置对象来进行路由的配置
路由切换: 可以通过
<Link>
Redirect
进行路由的切换路由加载: 可以同步记载,也可以异步加载,这样就可以实现按需加载
使用方式: 不仅可以在浏览器端的使用,而且可以在服务器端的使用
当然react-router
的缺点就是API不太稳定,在升级版本的时候需要进行代码变动。