vue监听路由变化的几种方式小结
目录
- 监听路由变化的几种方式小结
- 一、监听路由从哪儿来到哪儿去
- 二、监听路由变化获取新老路由信息
- 三、监听路由变化触发方法
- 四、全局监听路由
- 如何在组件中监听路由参数的变化?
- 方式一: 监听 $route
- 方式二:通过组件内的导航守卫
监听路由变化的几种方式小结 vue页面开发中,我们经常需要根据路由的变化去实现一些操作,那么如何监听路由的变化呢?当然是利用VUE中的watch,请看代码。
一、监听路由从哪儿来到哪儿去
watch:{$route(to,from){console.log(from.path); //从哪来console.log(to.path); //到哪去}}
二、监听路由变化获取新老路由信息
watch:{$route:{handler(val,oldval){console.log(val); //新路由信息console.log(oldval); //老路由信息},// 深度观察监听deep: true}}
三、监听路由变化触发方法
methods:{getPath(){console.log(1111)}},watch:{'$route':'getPath'}
四、全局监听路由
在app.vue的create种加入下面代码,然后进行判断
this.$router.beforeEach((to, from, next) => {console.log(to); next(); });
如何在组件中监听路由参数的变化? 当使用路由参数时,例如从 /user/foo 导航到 /user/bar,原来的组件实例会被复用。
因为两个路由都渲染同个组件,比起销毁再创建,复用则显得更加高效。不过,这也意味着组件的生命周期钩子不会再被调用。
那如果我们要在组件中监听路由参数的变化,就只能通过watch (监测变化) $route 对象,或使用 beforeRouteUpdate 的组件内守卫。
方式一: 监听 $route
const User = {template: '...',watch: {$route(to, from) {// 对路由变化作出响应...}}}
方式二:通过组件内的导航守卫
beforeRouteUpdate ,(和created(){}生命周期函数同级别)
const User = {template: '...',beforeRouteUpdate(to, from, next) {// react to route changes...// don't forget to call next()}}
【vue监听路由变化的几种方式小结】以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
推荐阅读
- VUEX
- 前端|IDEA打开vue项目并运行
- typescript|Vue.js 3 + Vite + TypeScript 实战项目开发
- vue|【实战篇】使用 Vue3 + Ts + Egg 开发一个ProTable(包含接口实现)
- 技术分享|使用 SpringBoot + Redis + Vue3 + ArcoPro 开发管理系统
- javascript|Vue3 + Vite2 项目实战复盘总结(干货!)
- vue.js|vue3+antd实现table中点击具体某一列展示弹窗
- vue|Vue+element-ui+ts封装table业务组件
- 基于axios在vue中的使用
- vue中get和post请求的区别点总结