标签:hash React location 原理 组件 Router history
React-Router原理分析
文章目录
一、两种模式:hash和history
在HTML5 historyAPI出来前前端的路由都是通过hash(‘#’)来实现的,服务器不会解析路径中的‘#’,但是js可以通过window.location.hash
读取到,当hash值发生改变时读取到hash值来匹配组件进行渲染。
history是HTML5新有的API,用来操作浏览器的session history(会话历史),表现形式和原有的路径一样不用‘#’而是用‘/’。但这种方式需要服务器后端有路径所对应的印射文件。
二、React-Router
当URL发生改变时(会触发hashchange
或history.popstate事件,改变URL),会调用history.pushState()方法,将路径状态压入栈(两种模式都会将新路由信息压入栈,只不过一个有‘#’一个没‘#’),同时得到location对象。接下来matchRoutes方法会匹配出Route组件树中与location对象所对应的组件,并得到nextState,最后顶用Router组件中的this.setState(nextState),渲染对应组件。
参考博文:https://www.jianshu.com/p/7044952626bf
标签:hash,React,location,原理,组件,Router,history 来源: https://blog.csdn.net/wdhxs/article/details/114373491
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。