关于Hash和History两种路由模式原理的精简笔记

本篇文章是关于HashHistory两种模式原理的精简笔记,可用于速记和复习

来由

由于传统的浏览器URL变化是会向服务端重新请求并刷新页面,不同的URL对应不同的页面、不同的资源,导致每次路由切换的时候都会去刷新页面,用户体验很差;所以为了提升用户体验,前端路由就出现了。

HashHistory对应于SPA(单页面)应用的两种路由模式,它们的本质都是改变浏览器URL且不刷新页面,监听其变化,触发自定义的路由处理方案。

Hash模式原理

首先Hash就是常见的地址栏中的#后面的字符,location.hash获取和设置hash值,原本是用来做页面定位的,称之为锚点,能够使页面定位到对应id的元素。Hash相较于History推出较早。路由的Hash模式的原理如下:

  • 使用hash值来匹配对应路由
  • hash值的改变不会使浏览器刷新
  • 使用hashChange来监听hash值的变化,从而触发自定义的路由处理方案,浏览器的前进后退也会触发hashChange
  • 比较老的方案,兼容性没问题

History原理

History是H5推出的API,兼容性没有Hash好,主要是利用popState事件来监听历史栈的变化,gobackforward能够触发该事件从而触发自定义的路由处理方案,pushStatereplaceState会改变URL但不会触发该事件,需要手动触发自定义的路由处理方案。原理如下:

  • 使用history的新API来进行处理,新API如下:
    • gobackforward
    • pushStatereplaceState 其中gobackforward才会触发popState事件
  • pushStatereplaceState会改变浏览器地址但不会让浏览器刷新
  • history路由的实现逻辑就是,手动的跳转使用popStatereplaceState,并且主动触发自定义的路由处理方案;浏览器点击的跳转触发popState事件从而触发自定义的路由处理方案。
  • H5的新API,对于IE有兼容性
  • 刷新会有问题,需要服务端支持,假如不是首页路径,就会出错;需要后端处理成:遇到不认识的路径也返回相同的html
相关推荐
web打印社区5 小时前
使用React如何静默打印页面:完整的前端打印解决方案
前端·javascript·vue.js·react.js·pdf·1024程序员节
喜欢踢足球的老罗5 小时前
[特殊字符] PM2 入门实战:从 0 到线上托管 React SPA
前端·react.js·前端框架
小光学长5 小时前
基于Vue的课程达成度分析系统t84pzgwk(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
前端·数据库·vue.js
Baklib梅梅6 小时前
探码科技再获“专精特新”认定:Baklib引领AI内容管理新方向
前端·ruby on rails·前端框架·ruby
南方以南_6 小时前
Chrome开发者工具
前端·chrome
YiHanXii6 小时前
this 输出题
前端·javascript·1024程序员节
Dream it possible!6 小时前
LeetCode 面试经典 150_链表_合并两个有序链表(58_21_C++_简单)
leetcode·链表·面试·1024程序员节
楊无好6 小时前
React中ref
前端·react.js
维他命Coco6 小时前
js常见开发学习
javascript
程琬清君6 小时前
vue3 confirm倒计时
前端·1024程序员节