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"]
}
网友评论