hash模式和history模式

本文探讨了浏览器路由的两种主要模式——Hash模式和History模式。Hash模式利用URL中的#符号来实现页面的无刷新更新,不涉及服务器交互,而History模式则允许更灵活的历史状态管理,通过pushState和replaceState操作改变URL并更新页面,同时监听popState事件。这两种模式在前端开发中各有应用场景,理解其工作原理对于优化用户体验至关重要。

hash模式,浏览器会自带#,#后面的字符都是hash,hash虽然在url中,但不会在http请求中,对服务器安全性没有影响,hash不会重新加载页面。
history模式,可以浏览历史栈,也可以修改(pushState(),replaceState()),可以监听状态变更(popState)

回答: 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.pushStatehistory.replaceState改变URL,不会引起页面的刷新,只会更新浏览器的历史记录。\[3\] #### 引用[.reference_title] - *1* *3* [前端路由原理?两种实现方式有什么区别?](https://blog.youkuaiyun.com/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.youkuaiyun.com/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 ]
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值