vue.js 怎么监听路由变化? 下面本篇文章给大家介绍一下 vue.JS 监听路由变化的方法. 有一定的参考价值, 有需要的朋友可以参考一下, 希望对大家有所帮助.
方法一: 通过 watch
- // 监听, 当路由发生变化的时候执行
- watch:{
- $route(to,from){
- console.log(to.path);
- }
- },
或
- // 监听, 当路由发生变化的时候执行
- watch: {
- $route: {
- handler: function(val, oldVal){
- console.log(val);
- },
- // 深度观察监听
- deep: true
- }
- },
或
- // 监听, 当路由发生变化的时候执行
- watch: {
- '$route':'getPath'
- },
- methods: {
- getPath(){
- console.log(this.$route.path);
- }
- }
方法二: key 是用来阻止 "复用" 的
Vue 为你提供了一种方式来声明 "这两个元素是完全独立的 -- 不要复用它们". 只需添加一个具有唯一值的 key 属性即可 (Vue 文档原话)
- <router-view :key="key"></router-view>
- computed: {
- key() {
- return this.$route.name !== undefined? this.$route.name +new Date(): this.$route +new Date()
- }
- }
使用 computed 属性和 Date() 可以保证每一次的 key 都是不同的, 这样就可以如愿刷新数据了.
方法二: 通过 vue-router 的钩子函数 beforeRouteEnter beforeRouteUpdate beforeRouteLeave
- <script>
- // 引入 Tabbar 组件
- import mTabbar from './components/Tabbar'
- import mTabbarItem from './components/TabbarItem'
- // 引入 vuex 的两个方法
- import {mapGetters, mapActions} from 'vuex'
- export default {
- name: 'app',
- // 计算属性
- computed:mapGetters([
- // 从 getters 中获取值
- 'tabbarShow'
- ]),
- // 监听, 当路由发生变化的时候执行
- watch:{
- $route(to,from){
- if(to.path == '/' || to.path == '/Prisoner' || to.path == '/Goods' ||
- to.path == '/Time' || to.path == '/Mine'){
- /**
- * $store 来自 Store 对象
- * dispatch 向 actions 发起请求
- */
- this.$store.dispatch('showTabBar');
- }else{
- this.$store.dispatch('hideTabBar');
- }
- }
- },
- beforeRouteEnter (to, from, next) {
- // 在渲染该组件的对应路由被 confirm 前调用
- // 不! 能! 获取组件实例 `this`
- // 因为当钩子执行前, 组件实例还没被创建
- },
- beforeRouteUpdate (to, from, next) {
- // 在当前路由改变, 但是该组件被复用时调用
- // 举例来说, 对于一个带有动态参数的路径 /foo/:id, 在 /foo/1 和 /foo/2 之间跳转的时候,
- // 由于会渲染同样的 Foo 组件, 因此组件实例会被复用. 而这个钩子就会在这个情况下被调用.
- // 可以访问组件实例 `this`
- },
- beforeRouteLeave (to, from, next) {
- // 导航离开该组件的对应路由时调用
- // 可以访问组件实例 `this`
- },
- components:{
- mTabbar,
- mTabbarItem
- },
- data() {
- return {
- select:"Building"
- }
- }
- }
- </script>
更多前端开发 https://www.html.cn/ 知识, 请查阅 HTML 中文网 !!
来源: http://www.css88.com/qa/vue-js/16963.html