前言
vue父子组件之间通过props很容易的将父组件的值传递给子组件,如果一个组件嵌套很多层,每一层之间度需要同props进行传值,很麻烦,且不易维护。vue通过provide & inject两个关键字完成父组件向子孙组件直接传值,很像子类能够使用父类的属性一样方便。provide & inject一般用于多层之间的传值,两层之间还是使用props进行。
示例
【示例】A组件中使用了B组件,B组件中使用了C组件,C组件需要使用A组件的数据text及使用A组件的方法getmethod。A组件代码如下:
<template>
<div>
<P>这是A组件</P>
<v-comb></v-comb>
</div>
</template>
<script>
import comB from '@/view/comB.vue'
export default {
name: 'comA',
components: {
'v-comb': comB
},
data() {
return {
msg: '我是组件A中数据'
}
},
provide: function() {
return {
text: this.msg,
getMethod: function() {
console.log('执行根组件中的getMethod方法')
}
}
}
}
</script>
使用关键字provide,将数据和方法暴露给子组件 B组件是A组件子组件,是C组件的父组件,代码如下
<template>
<div>
<div>
<P>这是B组件</P>
<v-comc></v-comc>
</div>
</div>
</template>
<script>
import comC from '@/view/comC.vue'
export default {
name: 'comB',
components: {
'v-comc': comC
}
}
</script>
C组件是A组件的孙子组件,C组件需要使用A组件的数据和方法,代码如下:
<template>
<div style="border:1px solid orange;color:orange;">
<div>
<P>这是C组件</P>
<div>{{text}}</div>
<button @click="getMethod">调用父组件方法</button>
</div>
</div>
</template>
<script>
export default {
name: 'comC',
inject: ['text', 'getMethod']
}
</script>
这里使用inject关键字,接收A组件暴露的信息,这里特别注意, inject: []中接收名字必须与provide提供的名字完全一致。
运行,界面如下图所示
小结
多层次组件嵌套通信,vue通过provide & inject两个关键字完成父组件向子孙组件直接传值,使用起来非常方便。存在问题子组件与父组件存在一种强耦合关系,不再万不得已时不建议使用。
|