Vue的路由的hash和history的实现原理

hash路由模式的实现主要是基于下面几个特性

URL 中 hash 值只是客户端的一种状态,也就是说当向服务器端发出请求时,hash 部分不会被发送;

hash 值的改变,都会在浏览器的访问历史中增加一个记录。因此我们能通过浏览器的回退、前进按钮控制hash 的切换;

可以通过 a 标签,并设置 href 属性,当用户点击这个标签后,URL 的 hash 值会发生改变;或者使用 JavaScript 来对 loaction.hash 进行赋值,改变 URL 的 hash 值;

我们可以使用 hashchange 事件来监听 hash 值的变化,从而对页面进行跳转(渲染)。

history模式的实现原理

history 路由模式的实现主要基于存在下面几个特性:

pushState 和 repalceState 两个 API 来操作实现 URL 的变化 ;

我们可以使用 popstate 事件来监听 url 的变化,从而对页面进行跳转(渲染);

history.pushState() 或 history.replaceState() 不会触发 popstate 事件,这时我们需要手动触发页面跳转(渲染)。

Vue 路由中的 hash 模式 history 模式存在多方面的区别: - **URL 表现形式**:hash 模式的 URL 中会带有 `#` 符号,例如 `http://example.com/#/home`;而 history 模式的 URL 则更像传统的 URL,没有 `#` 符号,如 `http://example.com/home` [^1][^2][^3]。 - **兼容性**:hash 模式的兼容性强,因为 `#` 后面内容的变化不会向服务器发送请求,几乎所有的浏览器都支持;history 模式需要浏览器支持 HTML5History API,对于一些旧版本浏览器不兼容 [^2]。 - **SEO 优化**:hash 模式的 URL 美观性 SEO 较差,搜索引擎一般不会抓取 `#` 后面的内容;history 模式提供了更自然的 URL,对 SEO 更友好 [^2]。 - **锚点功能**:hash 本来是用于页面定位的,如果拿来做路由,原来的锚点功能就不能用了,而 history 模式不存在此问题 [^3]。 - **传参限制**:hash 的传参是基于 URL 的,如果要传递复杂的数据,会有体积的限制;而 history 模式不仅可以在 URL 里放参数,还可以将数据存放在一个特定的对象中 [^3]。 - **刷新问题**:hash 模式下,页面刷新时不会向服务器发送新的请求,不会出现找不到资源的问题;history 模式下,页面刷新时会实实在在地发送请求,把 URL 传送给服务器,如果后端没有做处理,就会因找不到资源而报 404 错误,因此使用 history 模式时需要后端进行配合,配置服务器的 URL 重定向 [^4][^5]。 ### 代码示例 #### hash 模式 ```javascript const router = new VueRouter({ mode: 'hash', routes: [ { path: '/home', component: Home } ] }) ``` #### history 模式 ```javascript const router = new VueRouter({ mode: 'history', routes: [ { path: '/home', component: Home } ] }) ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值