提示:前端查漏补缺,仅代表个人观点,不接受如何批评

文章目录

  • 一、前端路由实现了什么?
  • 二、hash模式
    • 1.介绍
    • 2.特点
  • 三.history模式
    • 1.介绍
    • 2.特点
    • 3.history存在问题
  • 三.404错误
  • 总结

一、前端路由实现了什么?

  • 从用户角度看 前端路由实现了两个功能(使用ajax更新页面状态的情况下)

     1、`记录当前页面的状态`(保存或分享当前页的url,再次打开该url时,网页还是保存的(分享)时的状态);2、`可使用浏览器的前进后退功能`(如点击后退按钮,可以使页面回到ajax更新页面之前的状态,url也回到之前的状态)
    

  • 作为开发者,要实现这两个功能,我们需要做到:

     1、改变url且不让浏览器向服务器发出请求;2、监测url的变化;3、截获url地址,并解析出需要的信息来匹配路由规则。
    

二、hash模式

1.介绍

  • 这里的hash就是指url尾巴后的#号以及后面的字符。这里的#和css里的#是一个意思。hash也称作锚点,本身是用来做页面定位的,他可以使对应的id元素显示在可视区域内。

  • 由于hash值变化不会导致浏览器向服务器发出请求,而且hash改变会触发hashchange事件,浏览器的进后退也能对其进行控制,所以人们在html5的history出现前,基本都是使用hash来实现前端路由的。他的特点在于:hash虽然出现url中,但不会被包含在HTTP请求中,对后端完全没有影响,因此改变hash不会重新加载页面。hash 本来是拿来做页面定位的,如果拿来做路由的话,原来的锚点功能就不能用了。

  • 其次,hash的而传参是基于url的,如果要传递复杂的数据,会有体积的限制

示例代码:

window.location.hash='qq'//设置 url 的 hash,会在当前url后加上'#qq'var hash = window.location.hash //'#qq'window.addEventListener('hashchange',function(){//监听hash变化,点击浏览器的前进后退会触发
})

2.特点

  • hash变化会触发网页跳转,即浏览器的前进和后退。

  • hash 可以改变 url ,但是不会触发页面重新加载(hash的改变是记录在 window.history 中),即不会刷新页面。也就是说,所有页面的跳转都是在客户端进行操作。因此,这并不算是一次 http 请求,所以这种模式不利于 SEO 优化。hash 只能修改 # 后面的部分,所以只能跳转到与当前 url 同文档的 url 。

  • hash 通过 window.onhashchange 的方式,来监听 hash 的改变,借此实现无刷新跳转的功能。

  • hash 永远不会提交到 server 端(可以理解为只在前端自生自灭)。


三.history模式

1.介绍

history API 是 H5提供的新特性,允许开发者直接更改前端路由,即更新浏览器 URL地址而不重新发起请求。

  • history模式不仅可以在url里放参数,还可以将数据存放在一个特定的对象中。

  • history———利用了HTML5 History Interface 中新增的pushState()和replaceState()方法。(需要特定浏览器的支持)history不能运用与IE8一下

示例代码:

window.history.pushState(state,title,url)
//state:需要保存的数据,这个数据在触发popstate事件时,可以在event.state里获取
//title:标题,基本没用,一般传null
//url:设定新的历史纪录的url。新的url与当前url的origin必须是一样的,否则会抛出错误。url可以时绝对路径,也可以是相对路径。
//如 当前url是 https://www.baidu.com/a/,执行history.pushState(null, null, './qq/'),则变成 https://www.baidu.com/a/qq/,
//执行history.pushState(null, null, '/qq/'),则变成 https://www.baidu.com/qq/window.history.replaceState(state,title,url)
//与pushState 基本相同,但她是修改当前历史纪录,而 pushState 是创建新的历史纪录window.addEventListener("pospstate",function(){//监听浏览器前进后退事件,pushState与replaceState方法不会触发
})
window.history.back()//后退
window.history.forward()//前进
window.history.go(1)//前进一部,-2回退两不,window.history.lengthk可以查看当前历史堆栈中页面的数量

2.特点

  • 新的 url 可以是与当前 url 同源的任意 url ,也可以是与当前 url 一样的地址,但是这样会导致的一个问题是,会把重复的这一次操作记录到栈当中。

  • 通过 history.state ,添加任意类型的数据到记录中。

  • 可以额外设置 title 属性,以便后续使用。

  • 通过 pushState 、 replaceState 来实现无刷新跳转的功能。

3.history存在问题

  • 使用 history 模式时,在对当前的页面进行刷新时,此时浏览器会重新发起请求。如果 nginx 没有匹配得到当前的 url ,就会出现 404 的页面。

  • 而对于 hash 模式来说, 它虽然看着是改变了 url ,但不会被包括在 http 请求中。所以,它算是被用来指导浏览器的动作,并不影响服务器端。因此,改变 hash 并没有真正地改变 url ,所以页面路径还是之前的路径, nginx 也就不会拦截。

  • 因此,在使用 history 模式时,需要通过服务端来允许地址可访问,如果没有设置,就很容易导致出现 404 的局面。


三.404错误

  • 1、hash模式下,仅hash符号之前的内容会被包含在请求中,如 http://www.abc.com 因此对于后端来说,即使没有做到对路由的全覆盖,也不会返回404错误;
  • 2、history模式下,前端的url必须和实际后端发起请求的url一致,如http://www.abc.com/book/id 。如果后端缺少对/book/id 的路由处理,将返回404错误

总结



  • 这两个方法应用于浏览器的历史纪录站,在当前已有的back、forward、go 的基础之上,他们提供了对历史纪录进行修改的功能,只是当他们执行修改使,虽然改变了当前的url,但你的浏览器不会立即像后端发送请求。

  • To B 的系统推荐用 hash ,相对简单且容易使用,且因为 hash 对 url 规范不敏感;

  • To C 的系统,可以考虑选择 H5 history ,但是需要服务端支持;

前端常见问题以及处理方式 - - - (二)前端路由的两种模式和区别相关推荐

  1. vue-router前端路由的两种模式的区别

    一.前端路由存在的意义 前端路由主要应用在spa项目中. 核心---在无刷新(不向后端发送请求)的情况下,可以根据不同url更改视图. 二.浏览器提供hash 和history 两种模式支持(可以说, ...

  2. Vue-Router前端路由的两种模式、区别、原理?

    vue路由有⼏种模式?有什么区别?原理是什么? 一.vue路由有几种模式? 二.两者区别 三.原理 一.vue路由有几种模式? vue的路由模式⼀共有两种,分别是哈希和history 二.两者区别 哈 ...

  3. 前端路由的两种模式:hashhistory

    前端路由的两种模式:hash和history 1.hash hash模式是通过onhashchange事件,监听url的修改优点:兼容性比较高,可以直接在项目部署上线时使用缺点:url中带#号,不美观 ...

  4. vue路由的两种模式:hash与history的区别

    前言:众所周知,vue-router有两种模式,hash模式和history模式,下面来看看两者的区别. 一.基本情况 直观区别:hash模式url带#号,history模式不带#号. 1.hash模 ...

  5. vue路由之路由的两种模式

    文章目录 简介 hash路由 history模式 两种模式的比较 history存在的问题 专栏目录请点击 简介 一般路由分两种形式 一种是哈希路由,最明显的特征就是路由中有一个# 还有一种就是his ...

  6. oracle轮询方式循环输出,LGWR的两种模式(POST/WAIT和POLLING)

    11.2之前,oracle的lgwr写入模式为post/wait 11.2之后新增了polling模式,可以与post/wait模式自动切换 通过隐藏参数 _use_adaptive_log_file ...

  7. 【知识梳理】前端路由的两种模式

    一.概述 这是几年前写的的一篇文章,发在了简书上面,现在看来仍然有一些不足,所以再次整理一下发在掘金. 二.什么是单页面应用(SPA)? 首先我们需要了解一下前置的基础知识----SPA(单页面应用) ...

  8. stm32简明教程系列(二)----GPIO(上)八种模式的区别与应用场合

    一.概述 GPIO全称为通用输入/输出端口.是stm32用于输出信号,输入信号的通道.他有以下八种模式: 输入方式 浮空输入 GPIO_Mode_IN_FLOATING 上拉GPIO_Mode_IPU ...

  9. 前端开发:vue-router的使用以及两种模式的区别

    前言 在前端开发中,使用Vue做项目的时候关于路由的管理处理是非常重要的知识点,路由的管理也是比较常用的,做前端开发的都知道SPA,通过唯一一个HTML页面完成所有组件的展示和切换,不同组件之间的切换 ...

最新文章

  1. 项目快速开发的几点感悟
  2. Android之从Camera捕获图像讲解
  3. 谢尔排序/缩减增量排序(C++)
  4. 地理信息系统(GIS)
  5. 嵌套循环连接,哈希连接,排序合并连接(2015-2-4学习日记)
  6. CentOS 7 巨大变动之 firewalld 取代 iptables
  7. python带通配符的字符串匹配_Bash技巧:实例介绍数个参数扩展表达式以处理字符串变量...
  8. javafx性能_对JavaFX Mobile应用程序进行性能分析
  9. [Diary]6.10
  10. 反向算法_10分钟带你了解神经网络基础:反向传播算法详解
  11. opencv+Java+android 灰度图像
  12. 矩池云上如何修改cuda版本
  13. MapGIS数据中心是什么?
  14. 记一次 ClickHouse 性能测试
  15. python mysqldb 安装_python MySQLdb在windows环境下的快速安装、问题解决方式
  16. 浅析原代细胞应用现状
  17. 万兴剪刀手去水印教程_万兴神剪手怎么去水印 去除logo水印方法
  18. Codeforces Round #783 (Div. 2) A-F
  19. Android Binder机制学习总结(二)-Driver部分
  20. linux centos7以上的自带监控界面cockpit案例

热门文章

  1. 网众无盘服务器 快车挂盘失败 显示 当前磁盘已经为超级工作站模式,网众快车...
  2. 网页403是怎么回事?网页403的原因和解析。
  3. 2.1.4 字符与字符串编码
  4. Roofline模型初步
  5. Google啊,你伤不起啊伤不起
  6. Fluent UDF中直接调用CoolProp物性库
  7. #include<stdlib.h>
  8. 通达信最新交易接口系统开发源码有哪些?
  9. Win2008_server_r2虚拟机打开wireshark显示没有接口的【解决方法】
  10. 番外7林芝·救赎之旅的最后一站·中——AI主题科幻小说《地与光》