- $attrs は、祖父母から孫にデータを渡すために使用されます。
- $listener は、孫から祖父母コンポーネントでイベントをトリガーするために使用されます。
$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>
要約:
実際$attrs
、$listeners
同等のものはトランジットであり、主に親コンポーネントで使用されます。祖父と孫のコンポーネントは以前の使用を維持できます。