Rumah  >  Artikel  >  hujung hadapan web  >  Bagaimana untuk menggunakan menyediakan dan menyuntik untuk komunikasi komponen merentas peringkat dalam Vue?

Bagaimana untuk menggunakan menyediakan dan menyuntik untuk komunikasi komponen merentas peringkat dalam Vue?

WBOY
WBOYasal
2023-07-18 19:03:241061semak imbas

Bagaimana untuk menggunakan menyediakan dan menyuntik untuk komunikasi komponen merentas peringkat dalam Vue?

Dalam pembangunan Vue, komunikasi komponen merentas peringkat adalah keperluan biasa. Vue menyediakan cara yang mudah dan cekap untuk mencapai komunikasi komponen merentas peringkat, iaitu melalui penyediaan dan suntikan. Artikel ini akan memperkenalkan cara menggunakan menyediakan dan menyuntik dalam Vue untuk mencapai komunikasi komponen merentas peringkat dan melampirkan contoh kod yang sepadan.

Pertama, kita perlu memahami konsep asas menyediakan dan menyuntik.

menyediakan dan menyuntik ialah cara istimewa dalam Vue untuk komponen induk menghantar data kepada komponen turunan. Sediakan data dengan menggunakan sediakan dalam komponen induk, dan kemudian gunakan suntikan dalam komponen turunan untuk mendapatkan data ini.

menyediakan pilihan boleh menjadi objek atau fungsi. Kunci objek akan digunakan sebagai nama harta apabila menggunakan inject dalam komponen turunan, dan nilai akan digunakan sebagai data yang akan dihantar. Jika pilihan sediakan ialah fungsi, objek boleh dikembalikan di dalam fungsi dan nilai utama objek ini akan digunakan sebagai data yang diberikan kepada komponen turunan.

Dalam komponen keturunan, anda boleh menggunakan pilihan suntikan untuk menyuntik data yang disediakan oleh komponen induk. Pilihan suntikan boleh menjadi tatasusunan atau objek. Jika pilihan suntikan ialah tatasusunan, elemen tatasusunan akan digunakan sebagai nama harta yang akan diperolehi. Jika pilihan suntikan ialah objek, kunci objek akan digunakan sebagai nama harta dan nilai akan menjadi nilai lalai yang disediakan.

Di bawah ini kami menggunakan contoh untuk menunjukkan cara menggunakan menyediakan dan menyuntik untuk komunikasi komponen merentas peringkat.

Dalam komponen induk, kami menyediakan data yang dipanggil mesej untuk komponen turunan untuk digunakan:

<template>
  <div>
    <ChildComponent></ChildComponent>
  </div>
</template>

<script>
import ChildComponent from './ChildComponent.vue';

export default {
  components: {
    ChildComponent,
  },
  provide: {
    message: 'Hello, World!',
  },
};
</script>

Dalam komponen anak, kami menggunakan pilihan suntikan untuk mendapatkan data yang disediakan oleh komponen induk dan menggunakannya dalam templat:

<template>
  <div>
    <p>{{ injectedMessage }}</p>
  </div>
</template>

<script>
export default {
  inject: ['message'], // 这里使用数组形式注入要获取的数据
  computed: {
    injectedMessage() {
      return this.message;
    },
  },
};
</script>

Melalui kod di atas, kami telah berjaya melaksanakan komponen induk untuk menghantar data kepada komponen anak, dan memperoleh serta memaparkan data dalam komponen anak.

Selain pilihan suntikan dalam bentuk tatasusunan, kami juga boleh menggunakan pilihan suntikan dalam bentuk objek untuk berkomunikasi merentasi komponen tahap melalui menyediakan dan menyuntik. Untuk pilihan suntikan dalam bentuk objek, kunci setiap ahli akan digunakan sebagai nama atribut, dan nilai akan digunakan sebagai nilai lalai atribut.

<template>
  <div>
    <GrandChildComponent></GrandChildComponent>
  </div>
</template>

<script>
import GrandChildComponent from './GrandChildComponent.vue';

export default {
  components: {
    GrandChildComponent,
  },
  provide() {
    return {
      greeting: this.greetings, // 将父组件中的greetings数据提供给后代组件使用
    };
  },
  data() {
    return {
      greetings: 'Hello, World!', // 作为提供给后代组件的数据
    };
  },
};
</script>

Dalam komponen cucu, kami menggunakan pilihan suntikan untuk mendapatkan data yang disediakan oleh komponen induk dan menggunakannya dalam templat:

<template>
  <div>
    <p>{{ greeting }}</p>
  </div>
</template>

<script>
export default {
  inject: {
    greeting: {
      default: 'Hi, there!', // 设置greeting的默认值
    },
  },
};
</script>

Dengan kod di atas, kami telah berjaya melaksanakan komponen induk untuk menghantar data kepada cucu komponen, dan gunakannya dalam komponen cucu Data diperoleh dan dipaparkan dalam komponen.

Ringkasan:

Melalui menyediakan dan menyuntik, kita boleh mencapai komunikasi komponen merentas peringkat dengan mudah. Komponen induk menyediakan data melalui pilihan menyediakan, dan komponen turunan memperoleh data melalui pilihan suntikan. Kita boleh menyuntik data menggunakan pilihan suntikan dalam bentuk tatasusunan atau objek. Apabila menggunakan menyediakan dan menyuntik untuk komunikasi komponen merentas peringkat, anda perlu memberi perhatian kepada konflik penamaan dan elakkan menggunakan data reaktif apabila menggunakan menyediakan.

Saya harap artikel ini dapat membantu anda memahami cara menggunakan menyediakan dan menyuntik untuk komunikasi komponen merentas peringkat dalam Vue, dan menerapkannya pada pembangunan sebenar.

Atas ialah kandungan terperinci Bagaimana untuk menggunakan menyediakan dan menyuntik untuk komunikasi komponen merentas peringkat dalam Vue?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn