Vue の孫コンポーネントのパス値

  • $attrs は、祖父母から孫にデータを渡すために使用されます。
  • $listener は、孫から祖父母コンポーネントでイベントをトリガーするために使用されます。

$attrs の使用:

  1. 親コンポーネント (index.vue) では、値を渡す props と同様に、親コンポーネントに渡す必要がある値をバインドします。
  2. 親コンポーネントでは、props を介して値を渡すことも同様ですが、ここで渡されるのは値ではなく $attrs です。
  3. 孫コンポーネントで 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 の使用:

  1. 親コンポーネント (index.vue) で、イベントをバインドします。
  2. 親コンポーネントでは、イベントのバインドに似ていますが、ここでバインドされるのは特定のイベントではなく、 イベント ですv-on="$listeners"
  3. 孫コンポーネントでは、$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同等のものはトランジットであり、主に親コンポーネントで使用されます。祖父と孫のコンポーネントは以前の使用を維持できます。

おすすめ

転載: blog.csdn.net/YZ_ZZZ24/article/details/126075551