vue中组件通信父??子通过props ,子??父通过$emit ,那么父??孙,孙??父呢?
通常使用的方法是通过vuex 。如果仅仅是传递数据,而不做其他处理,使用 vuex 处理有点大材小用。 data:image/s3,"s3://crabby-images/d4f53/d4f5330149055c9a09518d3f400cb50cb27862e7" alt="在这里插入图片描述" 所以就有了 $attrs / $listeners ,通常配合inheritAttrs 一起使用。(注意:是2.4新增的)
📙inheritAttrs
inheritAttrs的讲解参考官网,如下图所示: data:image/s3,"s3://crabby-images/16cb1/16cb10f5ae3cc3c4dff1b9bdf12560b61e428905" alt="在这里插入图片描述"
📙$attrs / $listeners
📒$attrs
📒$listeners
- 官网讲解
data:image/s3,"s3://crabby-images/583ba/583baa4a2ac19e7f5760814d7b6f54ebbe7c651c" alt="在这里插入图片描述" - 🌰例子
- 父组件(component_parent.vue)
<template>
<div>
<child :parent="parentString" :info="info" @updateInfo="updateInfo"></child>
</div>
</template>
<script>
import child from "./component_child"
export default {
name: '',
components: { child },
data() {
return {
parentString: "这是父组件",
info: {
name: "张三",
address: "陕西省"
}
}
},
methods: {
updateInfo() {
console.log('更新父组件');
}
},
};
</script>
- 子组件(component_child.vue)
<template>
<div>
<div>{{parent}}</div>
<div>子组件:{{$attrs}}</div>
<grandson v-bind="$attrs" :message="message" @childInfo="childInfo"></grandson>
</div>
</template>
<script>
import grandson from './component_grandson.vue'
export default {
name: '',
components: { grandson },
props: [parent],
data() {
return {
message: "这是子组件的传值"
};
},
mounted() {
console.log('child-listeners', this.$listeners);
},
methods: {
childInfo() {
console.log('更新子组件');
}
},
};
</script>
- component_grandson.vue
<template>
<div>孙子组件:{{$attrs}}</div>
</template>
<script>
export default {
name: '',
data() {
return {
};
},
mounted() {
console.log('grandson-listeners', this.$listeners);
this.$emit('updateInfo')
},
</script>
data:image/s3,"s3://crabby-images/e813b/e813b7476979dc3cdd170b9a3395c973630dd5ea" alt="在这里插入图片描述"
以上就是$attrs 和$listeners 的使用,有问题欢迎随时指出!🏄🏄🏄
|