网站首页 > 基础教程 正文
为什么推荐使用 hash 模式?
创建项目时,vue-router 默认使用 hash 模式,设置模式的时候到底该使用hash还是history模式呢?
先了解它们的实现原理,搞清楚之间的区别,就知道什么时候该选择什么模式了。
一、实现原理
hash 原理
hash 通过监听浏览器 onhashchange 事件变化,查找对应路由应用。通过改变 location.hash 改变页面路由。
history 原理
利用 html5 的history Interface 中新增的 pushState() 和 replaceState() 方法,改变页面路径。
history Interface 是浏览器历史记录栈提供的接口,可通过 back、forward、go 等,可以读取历览器历史记录栈的信息,pushState、repalceState 还可以对浏览器历史记录栈进行修改。
hash 与 history 区别对比:
hash | history |
有 # 号 | 没有 # 号 |
能够兼容到IE8 | 只能兼容到IE10 |
实际的url之前使用哈希字符,这部分url不会发送到服务器,不需要在服务器层面上进行任何处理 | 每访问一个页面都需要服务器进行路由匹配生成 html 文件再发送响应给浏览器,消耗服务器大量资源 |
刷新不会存在 404 问题 | 浏览器直接访问嵌套路由时,会报 404 问题。 |
不需要服务器任何配置 | 需要在服务器配置一个回调路由 |
二、为什么推荐使用 hash 模式?
理由:
1、从兼容角度分析。
hash 可以兼容到 IE8,而 history 只能兼容到 IE10。
2、从网络请求的角度分析。
使用 hash 模式,地址改变时通过 hashchange 事件,只会读取哈希符号后的内容,并不会发起任何网络请求。
而 history 模式,每访问一个页面都要发起网络请求,每个请求都需要服务器进行路由匹配、数据库查询、生成HTML文档后再发送响应给浏览器,这个过程会消耗服务器的大量资源,给服务器的压力较大。
3、服务器配置角度分析。
hash 不需要服务器任何配置。
history 进行刷新页面时,无法找到url对应的页面,会出现 404 问题。因为域名后面的路由是由前端控制的,后端只能保留域名部分,所以就会造成页面丢失的问题,需要服务器端添加一个回退路由,就能解决该问题了。
hash 模式不足
1、hash 模式中的 # 也称作锚点,这里的的 # 和 css 中的 # 是一个意思,所以在 hash 模式内,页面定位会失效。
2、hash 不利于 SEO(搜索引擎优化)。
3、白屏时间问题。浏览器需要等待 JavaScript 文件加载完成之后渲染 HTML 文档内容,用户等待时间稍长。
好了小编今天的文章就到此结束了,喜欢我的可以点个关注哦
- 上一篇: 从模特到摄影师,他是我的传奇恋人
- 下一篇: web前端入门到实战:js刷新当前页面的5种方式
猜你喜欢
- 2024-12-16 达·芬奇名画离奇失踪,凡·高自杀手枪将拍卖
- 2024-12-16 Posts - 7, Articles - 0, Comments - 2
- 2024-12-16 史上最全 vue-router 讲解 !!! vue $route $router
- 2024-12-16 一文让你彻底搞懂 vue-Router vue-router的方法
- 2024-12-16 通过 React Router V6 源码,掌握前端路由
- 2024-12-16 直接拿来用!盘点一些拯救头发的 JS 单行代码,网友:摸鱼必备啊
- 2024-12-16 「源码解析 」这一次彻底弄懂react-router路由原理
- 2024-12-16 web前端入门到实战:js刷新当前页面的5种方式
- 2024-12-16 从模特到摄影师,他是我的传奇恋人
- 2024-12-16 路由的两种模式:hash模式和 history模式
- 最近发表
- 标签列表
-
- gitpush (61)
- pythonif (68)
- location.href (57)
- tail-f (57)
- pythonifelse (59)
- deletesql (62)
- c++模板 (62)
- css3动画 (57)
- c#event (59)
- linuxgzip (68)
- 字符串连接 (73)
- nginx配置文件详解 (61)
- html标签 (69)
- c++初始化列表 (64)
- exec命令 (59)
- canvasfilltext (58)
- mysqlinnodbmyisam区别 (63)
- arraylistadd (66)
- node教程 (59)
- console.table (62)
- c++time_t (58)
- phpcookie (58)
- mysqldatesub函数 (63)
- window10java环境变量设置 (66)
- c++虚函数和纯虚函数的区别 (66)