hash模式和history模式

hash模式

hash模式就是把路径前面加多一个#,然后再连接到URL后面。#后面path的改变不会引起浏览器向服务器发送请求。

hash的原理是通过监听浏览器的hashchange事件,改变window.location.hash来改变hash值。

hash模式特点
  • URL中会有一个#
  • 改变URL中的hash值不会引起页面的重新加载
  • 不利于SEO优化
  • 刷新不会出现404

下面是vue-router中配置为hash模式,默认是hash模式

import {createWebHashHistory,createRouter} from 'vue-router'
const router=createRouter({
    history: createWebHashHistory(),
    routes: []
})

history模式

history模式利用HTML5中history的pushState()方法和replaceState()方法改变URL。history模式改变URL同样也不会引起页面的重新加载,它会记录浏览器历史,点击后退按钮会回到上一个页面。

history模式特点
  • URL中没有#
  • 同样不会引起页面重新加载
  • 找不到URL对应的页面会出现404

在vue-router中配置为history模式

import {createWebHistory,createRouter} from 'vue-router'
const router=createRouter({
    history: createWebHistory(),
    routes: []
})

解决404问题

由于vue是单页面应用,只有一个页面,对于不同的URL请求找不到相应的资源会出现404的情况。为了解决这个问题,需要在服务器上进行配置,当URL没有匹配任何资源就返回index.html页面。

下面这个是Nginx的配置

location / {
  try_files $uri $uri/ /index.html;
}

对上面try_files进行解读:try_files表示尝试读取服务器上静态文件,$uri是Nginx的一个变量,代表用户访问的地址,$uri表示访问的是一个文件,$uri/表示访问的是一个目录。try_files就是尝试到网站读取这个文件,有这个文件就返回;没有这个文件就查找这个目录,找到这个目录返回目录;如果没有找到目录返回最后一个参数/index.html,表示返回网站的index.html文件。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
回答: Hash模式History模式前端路由中两种常见的模式Hash模式在URL中带有#号,而History模式则没有。\[1\]\[2\]Hash模式只能更改哈希值,即#后面的内容,而History模式可以通过API设置任意的同源URL。\[1\]Hash模式无需后端配置,并且兼容性好,适合在开发中使用。而History模式在用户手动输入地址或刷新页面时会发起URL请求,需要后端配置index.html页面用于匹配不到静态资源的情况。\[1\]另外,使用History模式时,访问二级页面并刷新会出现404错误,需要与后端配合进行URL重定向,将其重定向到首页路由上。\[2\]History模式是HTML5新推出的功能,通过history.pushState和history.replaceState改变URL,不会引起页面的刷新,只会更新浏览器的历史记录。\[3\] #### 引用[.reference_title] - *1* *3* [前端路由原理?两种实现方式有什么区别?](https://blog.csdn.net/LuckXinXin/article/details/109471171)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [路由模式hashhistory模式](https://blog.csdn.net/duanhy_love/article/details/125556962)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值