Vue.js前端Vue专辑

Vue系列-provide&inject

2019-07-28  本文已影响1人  前端切克闹
why

Vue父子组件间可以通过props属性做向下参数传递,但如果对于更下一层的子孙级组件时,如果继续通过props来做传递就麻烦很多
基于此,我们可以通过provide和inject来实现这种子孙级的嵌套

how

在父组件通过provide声明提供的对象
在孙组件上通过inject 声明注入的变量名

在实例化孙组件时会一层层往父组件查询是否有provide提供的对象,如果有声明,根据key进行变量值注入

父组件
{
  provide:{
      name:"lijiaxin"
  }
}
子孙组件
{
  inject:["name"]
}

注:provide亦可以声明为函数,返回对象(对象可以返回响应式对象)

{
    data:{
        test:{
            name:"lijiaxin"
        }
    },
    provide:function(){
        return {
                test:this.test
        }
    }
}

{
  inject:["test"]
}
上一篇下一篇

猜你喜欢

热点阅读