美文网首页
路由的钩子

路由的钩子

作者: 奇妙雨 | 来源:发表于2018-05-16 21:39 被阅读0次

路由的钩子:(即导航守卫)

1.全局的,

const router = new VueRouter({ ... })
router.beforeEach((to, from, next) => {
// ...
})
2.单个路由独享的

const router = new VueRouter({
routes: [
{
path: '/foo',
component: Foo,
beforeEnter: (to, from, next) => {
// ...
}
}
]
})
3.组件级的。

beforeRouteEnter
beforeRouteUpdate (2.2 新增)
beforeRouteLeave

const Foo = {
template: ...,
beforeRouteEnter (to, from, next) {
// 在渲染该组件的对应路由被 confirm 前调用
// 不!能!获取组件实例 this
// 因为当守卫执行前,组件实例还没被创建
},
beforeRouteUpdate (to, from, next) {
// 在当前路由改变,但是该组件被复用时调用
// 举例来说,对于一个带有动态参数的路径 /foo/:id,在 /foo/1 和 /foo/2 之间跳转的时候,
// 由于会渲染同样的 Foo 组件,因此组件实例会被复用。而这个钩子就会在这个情况下被调用。
// 可以访问组件实例 this
},
beforeRouteLeave (to, from, next) {
// 导航离开该组件的对应路由时调用
// 可以访问组件实例 this
}
}
路由元信息:给路由表每项添加的meta

例如:

{
    name:'find',
    path:'/find',
    component:find,
    meta:{
      title:'我是发现组件',
    },

===========================5.16组件通讯==========================================

组件通讯
一、组件:组件是可复用的 Vue 实例

二、创建组件:

1.全局组件
Vue.component('my-component-name', {
  // ... 选项 ...
})

例如:

import Vue from 'vue';

//定义一个全局组件
Vue.component('myCom1',{
    template:"<div>我是组件{{ count }} <button @click='go'>click</button></div>",
    data() {
        return {
            count:100
        }
    },
    methods:{
        go() {
            console.log('我是组件1的go方法');
        }
    }
});

2.局部组件
    var ComponentA = { /* ... */ }
    
    然后在 components 选项中定义你想要使用的组件:
    
    new Vue({
      el: '#app'
      components: {
        'component-a': ComponentA,
      }

三、组件通讯

父传子:
1.创建两个组件A.vue和B.vue,并在A.vue中引入B.vue,并注册
2.在A.vue引入的子组件自身添加要传递的属性

      例如: <my-com1 :yonghu="user"  :dizhi="address" :age="age"></my-com1>

    3.在B组件中接收A.vue组件中传递过来的值,通过props接收

       具体props有两种写法:数组和对象(带验证)
        例如:
          export default {
          //  props:['yonghu','dizhi','age'],
            props:{
                'yonghu':{
                    type:[String]
                },
                'dizhi':{
                    type:String
                },
                'age':{
                    type:Number,
                    default:0
                }
    
            },

子传父:主要通过事件派发实现,具体通过$emit实现

    派发事件:$emit()
    接收事件:@事件名戒v-on

兄弟之间:(即非父子)

相关文章

  • vue路由钩子

    路由钩子 1.全局钩子2.某个路由独享钩子3.组件内钩子 全局钩子 beforeEach(全局前置守卫)、afte...

  • 2021-04-11

    vue-router 路由钩子函数(导航守卫) 路由钩子函数有三种: 全局钩子: beforeEach(全局前置守...

  • Vue-Router 导航守卫

    导航守卫 导航表示路由正在发生改变。(变化的路由)导航守卫就是变化的路由钩子。路由钩子的意思可以理解为vue-ro...

  • Vue-Router路由钩子函数(导航守卫)

    —— “导航”表示路由正在发生改变。 路由钩子函数有三种: 1:全局钩子: beforeEach、 ...

  • vue路由钩子函数的实战用法

    —— “导航”表示路由正在发生改变。 路由钩子函数有三种:​ 1:全局钩子: beforeE...

  • Vue-router 学习笔记

    路由钩子函数

  • Vue视频教程系列第三十五节—路由器里的钩子函数

    路由钩子函数介绍: 我之前有介绍过vue里的钩子函数,有四对,也就是八个钩子函数。在路由里呢,其实也有钩子函数,个...

  • vue router.beforeEach(({meta, pa

    导航和钩子函数: 导航:路由正在发生改变 关键字:路由 变 钩子函数:在路由切换的不同阶段调用不同的节点函数(钩...

  • 路由的钩子

    路由的钩子:(即导航守卫) 1.全局的, const router = new VueRouter({ ... }...

  • Vuerouter的beforeEach与afterEach钩子

    在路由跳转的时候,我们需要一些权限判断或者其他操作。这个时候就需要使用路由的钩子函数。 定义:路由钩子主要是给使用...

网友评论

      本文标题:路由的钩子

      本文链接:https://www.haomeiwen.com/subject/animdftx.html