vue中怎么监听url地址栏参数变化

发布时间:2023-03-10 11:30:40 作者:iii
来源:亿速云 阅读:167

这篇“vue中怎么监听url地址栏参数变化”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“vue中怎么监听url地址栏参数变化”文章吧。

vue监听url地址栏参数变化

问题:

在开发过程中我们有可能会遇到一个问题,就是在一个vue项目中引入了一个组件,点击这个组件跳转的还是当前的页面,只是传递的参数发生了变化,这个时候我们传递的参数就不能正常的赋值了,这是因为页面没有重新加载,所以我们就要监听地址栏的参数变化了。

1、传递参数

    this.$router.push({
        path: url,//路由地址
        query:{//参数
            type: 1
        }
    });

2、监听参数变化

    watch: {
        //监听路由地址的改变
        $route:{
            immediate:true,
            handler(){
                if(this.$route.query.type){//需要监听的参数
                    this.type = this.$route.query.type
                }
            }
        }
    }

vue检测url的变化-Kaiqisan

之前尝试在vue中监听路由变化,发现在vue中无法使用window.location来监听,于是另外找了一种方法。

这个检测不会去检测域名,端口,协议的变化,只会检测端口后面的内容的变化,检测路由的值和参数的值.

'$route': {
    handler(val) {
        console.log(val);
    },
    deep: true
    // immediate: true
},

在vue中去监听$route就可以了,这里面包含了端口号后面的所有信息。

每一次跳转路由都会监听到路由的变化(甚至可以监听锚的变化和参数的变化),记得添加深度监听(其实在watch里面,待监听参数命名这里如果使用字符串—(’$route’)—的话就可以直接进入深度监听)

PS:如果您只是想要监听路由 单一部分 的变化的话,建议把监听对象写得更加详细一些,比如…

'$route.path'(val) {
    // ........
}

'$route.query'(val) {
    // ........
}

虽然还是深度监听,但是性能会大有提高。

最后测试的部分就交给大家了!

注意:建议把这个监听方法放在一个所有页面都会使用的公共组件上面,这样就可以常驻地监听而不会因为组件的切换而导致监听的失效。

以上就是关于“vue中怎么监听url地址栏参数变化”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注亿速云行业资讯频道。

推荐阅读:
  1. Vue的项目使用Element ui走马灯无法实现怎么办
  2. Vue打包部署到Nginx时,css样式不生效怎么办

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

vue url

上一篇:Android Compose如何实现联系人列表

下一篇:el-tree树组件懒加载怎么实现

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》