Hash 和 History 模式

本文详细介绍了Vue中Hash和History模式的区别。Hash模式利用#号及onhashchange事件进行路由切换,而History模式基于HTML5 History API,需要服务器配置以避免404错误。History模式在Node.js和Nginx服务器上的配置方法也进行了演示。
摘要由CSDN通过智能技术生成

 Hash 和 History 模式的区别

首先需要强调的是不管哪种模式都是客户端路由的实现方式,也就是当路径放生变化之后不会向服务器发送请求,是用 js 监视路径的变化的变化,然后根据不同的地址渲染不同的内容如果需要服务端内容的话,需要使用Ajax发送请求。

 

表现形式的区别

- Hash 模式

https://music.136.com/#/user?id=10029 这种模式的地址中带有 # 号, # 号后面就是路由地址可以使用 ? 携带路由参数,官方文档中说这种模式很丑,路径中带着一些与地址无关的符号,比如井号和问好。

- History 模式

https://music.136.com/user/10029 

 

原理的区别

- Hash 模式是基于锚点,以及 onhashchange 事件

通过锚点的值作为路由地址,当地址发生变化后触发 onhashchange 事件,根据路径决定页面渲染的内容。

- History 模式是基于 HTML5 中的 History API

 - history.pushState()  IE10 以后才支持

 - history.relplaceState() 

 

pushState 方法和 push 方法的区别

当调用 history.push 方法的时候,路径会发生变化,这个时候要想服务器发送请求,而调用 history.pushState 方法不会向

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值