vue 实现爷孙组件的数据通信
$attrs的使用:
-
在爷组件(index.vue)中,类似props传值,将需要传递的值绑定在父组件上。
-
在父组件中,也是类似props传值,但是这里传递的就不是值了,而是$attrs。
-
在孙组件中,接收props,这样就可以在孙组件中使用这个数据了。
(需要注意的是父组件中不需要接收props,只要在孙组件中接收就可以。)
//index.vue: <Father :homeInfo="homeInfo"/> //Father.vue: <Son v-bind="$attrs"/> //son.vue: <template> <div class="home"> {{homeInfo.name}} </div> </template> <script> export default { name: "Son", data() { return {}; }, props: { homeInfo: { default: Object, default: () => {}, }, }, }; </script>
$listeners的使用:
-
在爷组件(index.vue)中,绑定事件。
-
在父组件中,也是类似绑定事件,但是这里绑定的不是具体的事件,而是
v-on="$listeners"
。 -
在孙组件中,需要的时候触发(
$emit
)这个事件即可。
//index.vue: <Father :homeInfo="homeInfo" @update="update"/> //Father.vue: <Son v-bind="$attrs" v-on="$listeners"/> //son.vue: <template> <div class="home" @click="update"> {{homeInfo.name}} </div> </template> <script> export default { name: "Son", data() { return {}; }, props: { homeInfo: { default: Object, default: () => {}, }, }, methods: { update() { const newHome = { name: 'new' } this.$emit("update", newHome) } } }; </script>