Vue3中父子傳參常見方式及用法
在 Vue 3 中,父子組件之間進行通信有多種方式,下面簡單介紹下常見的方式及其用法和使用場景:
一、Props
用于父組件向子組件傳遞數(shù)據(jù)。
這是最基本也是最常用的一種方式。通過在子組件上定義 props,父組件可以將數(shù)據(jù)傳遞給子組件。在子組件中,通過 props 對象訪問這些屬性。
父組件:
<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
用于在父子組件之間實現(xiàn)雙向綁定。在 Vue 3 中,通過 v-model 方式進行組件通信需要使用 v-model 指令和 emit 事件。父組件使用 v-model 向子組件傳遞數(shù)據(jù),并通過子組件觸發(fā) ,用update:modelValue 事件來實現(xiàn)雙向綁定。
下面是一個簡單的例子:
子組件:
<!-- 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 事件,從而實現(xiàn)了父子組件之間的雙向綁定。
在父組件 ParentComponent 中,使用 v-model 將 ChildComponent 的 modelValue 綁定到 message 上,這樣在父組件中修改 message 的值會自動同步到 ChildComponent 中,反之亦然。
需要注意的是,v-model 實際上是一個語法糖,它會自動處理 value 和 input 事件。如果在子組件中使用 v-model,則子組件應(yīng)該接受名為 modelValue 的 prop,并發(fā)出一個名為 update:modelValue 的事件。這樣可以確保 v-model 在父子組件之間正確地進行雙向綁定。
三、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)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
解決Vue3?echarts?v-show無法重新渲染的問題
這篇文章主要介紹了Vue3?echarts?v-show無法重新渲染的問題,本文通過示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-09-09
如何使用Vue3.2+Vite2.7從0快速打造一個UI組件庫
構(gòu)建工具使用vue3推薦的vite,下面這篇文章主要給大家介紹了關(guān)于如何使用Vue3.2+Vite2.7從0快速打造一個UI組件庫的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-09-09

