Vue3中父子傳參常見方式及用法
在 Vue 3 中,父子組件之間進(jìn)行通信有多種方式,下面簡單介紹下常見的方式及其用法和使用場(chǎng)景:
一、Props
用于父組件向子組件傳遞數(shù)據(jù)。
這是最基本也是最常用的一種方式。通過在子組件上定義 props,父組件可以將數(shù)據(jù)傳遞給子組件。在子組件中,通過 props 對(duì)象訪問這些屬性。
父組件:
<template> <ChildComponent :message="parentMessage" /> </template> <script> import ChildComponent from './ChildComponent.vue'; export default { components: { ChildComponent, }, data() { return { parentMessage: 'Hello from parent!', }; }, }; </script>
子組件:
<template> <div>{{ message }}</div> </template> <script> export default { props: { message: String, }, }; </script>
二、v-model
用于在父子組件之間實(shí)現(xiàn)雙向綁定。在 Vue 3 中,通過 v-model 方式進(jìn)行組件通信需要使用 v-model 指令和 emit 事件。父組件使用 v-model 向子組件傳遞數(shù)據(jù),并通過子組件觸發(fā) ,用update:modelValue 事件來實(shí)現(xiàn)雙向綁定。
下面是一個(gè)簡單的例子:
子組件:
<!-- ChildComponent.vue --> <template> <input :value="message" @input="$emit('update:modelValue', $event)" /> </template> <script> export default { props: { modelValue: String, }, computed: { message: { get() { return this.modelValue; }, set(value) { this.$emit('update:modelValue', value); }, }, }, }; </script>
父組件:
<!-- ParentComponent.vue --> <template> <ChildComponent v-model="parentMessage" /> </template> <script> import ChildComponent from './ChildComponent.vue'; export default { components: { ChildComponent, }, data() { return { parentMessage: 'Hello from parent!', }; }, }; </script>
在子組件 ChildComponent 中,通過 :value=“modelValue” 將 modelValue 綁定到 input 元素上,然后通過 @input=“$emit(‘update:modelValue’, $event)” 觸發(fā) update:modelValue 事件,從而實(shí)現(xiàn)了父子組件之間的雙向綁定。
在父組件 ParentComponent 中,使用 v-model 將 ChildComponent 的 modelValue 綁定到 message 上,這樣在父組件中修改 message 的值會(huì)自動(dòng)同步到 ChildComponent 中,反之亦然。
需要注意的是,v-model 實(shí)際上是一個(gè)語法糖,它會(huì)自動(dòng)處理 value 和 input 事件。如果在子組件中使用 v-model,則子組件應(yīng)該接受名為 modelValue 的 prop,并發(fā)出一個(gè)名為 update:modelValue 的事件。這樣可以確保 v-model 在父子組件之間正確地進(jìn)行雙向綁定。
三、Provide/Inject:
用于祖先組件向后代組件傳遞數(shù)據(jù),通過 Provide 提供數(shù)據(jù),通過 Inject 注入數(shù)據(jù)。祖先組件通過 provide 提供數(shù)據(jù),后代組件通過 inject 接收數(shù)據(jù)。
祖先組件:
<template> <GrandparentComponent> <template v-slot="{ message }"> <ChildComponent :message="message" /> </template> </GrandparentComponent> </template> <script> import GrandparentComponent from './GrandparentComponent.vue'; export default { components: { GrandparentComponent, }, provide() { return { message: 'Hello from grandparent!', }; }, }; </script>
父組件:
<template> <slot :message="message" /> </template> <script> export default { inject: ['message'], }; </script>
子組件:
<template> <div>{{ message }}</div> </template> <script> export default { props: { message: String, }, }; </script>
四、事件
通過自定義事件,子組件向父組件傳遞數(shù)據(jù)。子組件通過 $emit 觸發(fā)自定義事件,父組件監(jiān)聽該事件接收數(shù)據(jù)。
子組件:
<template> <button @click="sendMessage">Send Message</button> </template> <script> export default { methods: { sendMessage() { this.$emit('message', 'Hello from child!'); }, }, }; </script>
父組件:
<template> <ChildComponent @message="handleMessage" /> </template> <script> import ChildComponent from './ChildComponent.vue'; export default { components: { ChildComponent, }, methods: { handleMessage(message) { console.log(message); }, }, }; </script>
四、Ref
使用 ref 可以將數(shù)據(jù)在父子組件之間共享。
父組件:
<template> <ChildComponent :message="sharedMessage" /> </template> <script> import { ref } from 'vue'; import ChildComponent from './ChildComponent.vue'; export default { components: { ChildComponent, }, setup() { const sharedMessage = ref('Hello from parent!'); return { sharedMessage }; }, }; </script>
子組件:
<template> <div>{{ message }}</div> </template> <script> import { ref, watchEffect } from 'vue'; export default { props: { message: String, }, setup(props) { const message = ref(props.message); watchEffect(() => { // 監(jiān)聽 props 中的 message 變化 message.value = props.message; }); return { message }; }, }; </script>
到此這篇關(guān)于Vue3中父子傳參的文章就介紹到這了,更多相關(guān)Vue3父子傳參內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
解決Vue3?echarts?v-show無法重新渲染的問題
這篇文章主要介紹了Vue3?echarts?v-show無法重新渲染的問題,本文通過示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-09-09如何使用Vue3.2+Vite2.7從0快速打造一個(gè)UI組件庫
構(gòu)建工具使用vue3推薦的vite,下面這篇文章主要給大家介紹了關(guān)于如何使用Vue3.2+Vite2.7從0快速打造一個(gè)UI組件庫的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-09-09