vue 直接输入路由地址进入_Vue地址栏直接输入路由无效问题的解决_茜茜_前端开发者...

在Vue项目中,使用history模式或hashchange事件进行路由跳转。打包后,通过地址栏直接修改路由在某些浏览器(如IE11)上可能不生效。解决方法是在App.vue中监听hashchange事件,对于IE浏览器,当路由不匹配时手动调用$router.push更新页面。这种方法确保了在地址栏输入路由后能正确跳转。
摘要由CSDN通过智能技术生成

路由管理器

最近项目有一个需求,是在地址栏输入路由,跳转到对应路由组件,在开发环境中这样做是可以跳转的,但是项目打包后,通过地址栏跳转会报错。

因为

方式一:history 模式

方式二:hashchange 事件

什么是 hash?

hash 就是 URL 地址中 # 字符后面的字符串。

更改它不会导致整个页面重新加载,而且可以定位到元素 id 或 name 与之相同的位置(锚点)。

window.location.hash可以获取到 hash。比如 localhost:8080/#/abcde 的 location.hash=”#/abcde”。

通过监听 hash 的状态,来动态修改

当 hash 被修改时,将触发 hashchange 事件(IE8 +支持):

window.addEventListener('hashchange',function(e) {

console.log(e.oldURL);

console.log(e.newURL)

},false);

所以在 App.vue 中添加此事件:

mounted(){

window.addEventListener('hashchange',()=>{

var currentPath = window.location.hash.slice(1); // 获取输入的

这样即可解决,在地址栏输入

补充:Vue

情景:在ie11上从当前A页面(/a)跳转B页面(/b),在地址栏直接修改路由回车跳转B页面,发现页面还是A页面,但是地址栏地址已经是B页面地址。而且控制台并无报错。

解决方法:在App.vue中添加判断ie加手动修复:

mounted () {

if (!!window.ActiveXObject || 'ActiveXObject' in window) {

window.addEventListener('hashchange', () => {

let currentPath = window.location.hash.slice(1)

if (this.$route.path !== currentPath) {

this.$router.push(currentPath)

}

}, false)

}

}

onhashchange事件ie8就已经支持了。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值