美文网首页Vue.js前端Vue专辑
Vue系列-provide&inject

Vue系列-provide&inject

作者: 前端切克闹 | 来源:发表于2019-07-28 20:35 被阅读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"]
    }
    

    相关文章

      网友评论

        本文标题:Vue系列-provide&inject

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