Rumah hujung hadapan web View.js 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?

Jul 18, 2023 pm 07:03 PM
vue provide inject

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>
Salin selepas log masuk

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>
Salin selepas log masuk

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>
Salin selepas log masuk

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>
Salin selepas log masuk

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 Laman Web ini
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

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Apakah kaedah menukar rentetan vue.js ke dalam objek? Apakah kaedah menukar rentetan vue.js ke dalam objek? Apr 07, 2025 pm 09:18 PM

Menggunakan json.parse () rentetan ke objek adalah yang paling selamat dan paling efisien: pastikan rentetan mematuhi spesifikasi JSON dan mengelakkan kesilapan biasa. Gunakan cuba ... menangkap untuk mengendalikan pengecualian untuk meningkatkan keteguhan kod. Elakkan menggunakan kaedah eval (), yang mempunyai risiko keselamatan. Untuk rentetan JSON yang besar, parsing parsing atau parsing tak segerak boleh dipertimbangkan untuk mengoptimumkan prestasi.

Vue.js vs React: Pertimbangan khusus projek Vue.js vs React: Pertimbangan khusus projek Apr 09, 2025 am 12:01 AM

Vue.js sesuai untuk projek kecil dan sederhana dan lelaran yang cepat, sementara React sesuai untuk aplikasi besar dan kompleks. 1) Vue.js mudah digunakan dan sesuai untuk situasi di mana pasukan tidak mencukupi atau skala projek kecil. 2) React mempunyai ekosistem yang lebih kaya dan sesuai untuk projek dengan prestasi tinggi dan keperluan fungsional yang kompleks.

Adakah vue.js sukar belajar? Adakah vue.js sukar belajar? Apr 04, 2025 am 12:02 AM

Vue.js tidak sukar untuk dipelajari, terutamanya bagi pemaju dengan asas JavaScript. 1) Reka bentuk progresif dan sistem responsif memudahkan proses pembangunan. 2) Pembangunan berasaskan komponen menjadikan pengurusan kod lebih cekap. 3) Contoh penggunaan menunjukkan penggunaan asas dan lanjutan. 4) Kesilapan biasa boleh disahpepijat melalui Vuedevtools. 5) Pengoptimuman prestasi dan amalan terbaik, seperti menggunakan V-IF/V-Show dan atribut utama, boleh meningkatkan kecekapan aplikasi.

Adakah Vue digunakan untuk frontend atau backend? Adakah Vue digunakan untuk frontend atau backend? Apr 03, 2025 am 12:07 AM

Vue.js terutamanya digunakan untuk pembangunan front-end. 1) Ia adalah rangka kerja JavaScript yang ringan dan fleksibel yang difokuskan pada membina antara muka pengguna dan aplikasi satu halaman. 2) Inti Vue.js adalah sistem data responsifnya, dan pandangannya dikemas kini secara automatik apabila data berubah. 3) Ia menyokong pembangunan komponen, dan UI boleh dibahagikan kepada komponen bebas dan boleh diguna semula.

Cara menggunakan bootstrap di vue Cara menggunakan bootstrap di vue Apr 07, 2025 pm 11:33 PM

Menggunakan bootstrap dalam vue.js dibahagikan kepada lima langkah: Pasang bootstrap. Import bootstrap di main.js. Gunakan komponen bootstrap secara langsung dalam templat. Pilihan: Gaya tersuai. Pilihan: Gunakan pemalam.

Cara menambah fungsi ke butang untuk vue Cara menambah fungsi ke butang untuk vue Apr 08, 2025 am 08:51 AM

Anda boleh menambah fungsi ke butang VUE dengan mengikat butang dalam templat HTML ke kaedah. Tentukan kaedah dan tulis logik fungsi dalam contoh Vue.

Cara merujuk fail js dengan vue.js Cara merujuk fail js dengan vue.js Apr 07, 2025 pm 11:27 PM

Terdapat tiga cara untuk merujuk kepada fail JS dalam vue.js: Secara langsung tentukan jalan menggunakan & lt; skrip & gt; tag ;; import dinamik menggunakan cangkuk kitaran hayat yang dipasang (); dan mengimport melalui Perpustakaan Pengurusan Negeri VUEX.

Cara Menggunakan Watch di Vue Cara Menggunakan Watch di Vue Apr 07, 2025 pm 11:36 PM

Pilihan Watch di Vue.js membolehkan pemaju mendengar perubahan dalam data tertentu. Apabila data berubah, tontonkan mencetuskan fungsi panggil balik untuk melakukan paparan kemas kini atau tugas lain. Pilihan konfigurasinya termasuk segera, yang menentukan sama ada untuk melaksanakan panggilan balik dengan serta -merta, dan mendalam, yang menentukan sama ada untuk mendengarkan secara rekursif terhadap objek atau tatasusunan.

See all articles