Rumah >hujung hadapan web >tutorial js >Membina Tindanan Pengeluaran: Docker, Meilisearch, NGINX & NestJS
Jika anda sudah biasa dengan Vue 2, anda mungkin ingat bahawa setiap templat komponen memerlukan satu elemen akar. Dalam Vue 3, itu tidak lagi diperlukan kerana serpihan. Ini bermakna komponen anda kini boleh mempunyai berbilang elemen akar tanpa memerlukan pembalut.
<!-- Vue 2 --> <template> <div> <!-- wrapper ? --> <h1>My Blog Post</h1> <ArticleComponent>{{ content }}</ArticleComponent> </div> </template> <!-- Vue 3 --> <template> <h1>My Blog Post</h1> <ArticleComponent>{{ content }}</ArticleComponent> </template>
Itu sangat serupa dengan Fragment in React. Walau bagaimanapun, Vue mengendalikan serpihan di sebalik tabir. Malah, dalam Vue 3, anda boleh memikirkan
Dalam Vue 2, kami boleh menetapkan ref pada komponen kanak-kanak dengan mudah, dan ia akan merujuk kepada kedua-dua elemen pembungkus dan contoh komponen.
Tetapi dalam Vue 3, apabila tiada elemen pembalut, apakah yang dimaksudkan oleh ref? ?
Jika komponen anak menggunakan API Pilihan atau tidak menggunakan
, ref akan menunjuk kepada komponen anak ini, memberikan induk akses penuh kepada sifat dan kaedahnya.
Bagaimana jika kita menggunakan
Komponen yang menggunakan
adalah peribadi secara lalai. Untuk mendedahkan sifat, kita perlu menggunakan makro defineExpose.
<!-- Child --> <template> <div>
<!-- Child --> <template> <h1>My Blog Post</h1> <!-- Root 1 --> <ArticleComponent>{{ content }}</ArticleComponent> <!-- Root 2 --> </template> <!-- Parent --> <script setup lang="ts"> const childRef = ref() onMounted(()=>{ console.log(childRef.value.$el); // #text }) </script> <template> <Child ref="childRef" /> </template>
Tunggu, apa, apa yang berlaku?
Apabila kami menggunakan Fragment(berbilang nod), Vue mencipta nod teks yang membalut nod akar komponen anak kami.
Apabila menggunakan Fragmen dalam Vue 3, Vue memasukkan nod teks kosong pada permulaan komponen sebagai penanda, itulah sebabnya $el mengembalikan nod #teks.
#teks adalah seperti titik rujukan yang digunakan oleh Vue secara dalaman.
Saya juga harus menyatakan bahawa anda masih mempunyai akses kepada contoh komponen (jika anda tidak menggunakan
1) Gunakan Single Root Seperti ini
2) Gunakan Rujukan Templat defineExpose
<!-- Child --> <script setup lang="ts"> import { ref } from 'vue'; const h1Ref = ref() const articleRef = ref() defineExpose({ h1Ref, articleRef }) </script> <template> <h1 ref="h1Ref">My Blog Post</h1> <ArticleComponent ref="articleRef">{{ content }}</ArticleComponent> </template> <!-- Parent --> <script setup lang="ts"> const childRef = ref() onMounted(()=>{ console.log(childRef.value); // {h1Ref: RefImpl, articleRef: RefImpl} }) </script> <template> <Child ref="childRef" /> </template>
Kini anda mempunyai akses kepada rujukan anda dan semua perkara yang anda dedahkan dengan menggunakan defineExpose.
Atas ialah kandungan terperinci Membina Tindanan Pengeluaran: Docker, Meilisearch, NGINX & NestJS. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!