Vue的子父組件傳值之小白必看篇
搭建的框架目錄結(jié)構(gòu)

一、父傳子動圖效果及源碼

父傳子源碼
父組件:
<template> ? <div> ? ? <div> ? ? ? <p v-html="theCardTitle"></p> ? ? ? <button @click="sendMessage">OK</button> ? ? </div> ? ? <div> ? ? ? <ChildCard :parentMessage="parentMessage"></ChildCard> ? ? </div> ? </div> </template>
<script>
import ChildCard from "../sub/ChildCard";
export default {
? data() {
? ? return {
? ? ? theCardTitle: "父組件",
? ? ? parentMessage: ""
? ? };
? },
? components: {
? ? ChildCard
? },
? methods: {
? ? sendMessage() {
? ? ? this.parentMessage = "<b>消息來自父組件:</b> (^_^)!";
? ? }
? },
};
</script>子組件:
<template> ? <div> ? ? <div> ? ? ? <p v-html="theCardBody"></p> ? ? ? <div v-html="parentMessage"></div> ? ? </div> ? </div> </template>
<script>
export default {
? props: ["parentMessage"],
? data() {
? ? return {
? ? ? theCardBody: "子組件"
? ? };
? }
};
</script>二、子傳父動圖效果

子傳父源碼
父組件:
<template>
? <div>
? ? <div>
? ? ? <p v-html="theCardTitle"></p>
? ? ? <span>{{parentMessage}}</span>
? ? ? <ChildCardOne @childByValue="childByValue"></ChildCardOne>
? ? </div>
? </div>
</template><script>
import ChildCardOne from "../sub/ChildCardOne";
export default {
? data() {
? ? return {
? ? ? theCardTitle: "父組件",
? ? ? parentMessage: ""
? ? };
? },
? components: {
? ? ChildCardOne
? },
? methods: {
? ? childByValue(childValue) {
? ? ? this.parentMessage = childValue;
? ? }
? }
};
</script>子組件:
<template>
? <div>
? ? <p v-text="theCardTitle"></p>
? ? <span>{{childValue}}</span>
? ? <div>
? ? ? <button @click="ok">OK</button>
? ? </div>
? </div>
</template><script>
export default {
? data() {
? ? return {
? ? ? theCardTitle: "子組件",
? ? ? childValue: "我是子組件的數(shù)據(jù)"
? ? };
? },
? methods: {
? ? ok() {
? ? ? this.$emit("childByValue", this.childValue);
? ? }
? }
};
</script>三、詳細(xì)解說組件傳遞過程:組件傳值模板
也可以說這部分的內(nèi)容是將組件的傳遞過程的關(guān)鍵代碼給抽離出來了,幫助大家更好的理解如何使用傳值!

1.父--->子
①屬性props
子組件利用props接收父組件傳遞過來的數(shù)據(jù)
指的是從外部設(shè)置的屬性,需子組件設(shè)置props屬性
注意:
props嚴(yán)格用于父組件與子組件之間的單向通訊,并且你不希望嘗試直接在子組件中更改props的值。
否則,將收到類似這樣的錯誤信息“避免直接修改某個prop,因為當(dāng)父組件重新渲染時,該值將被覆蓋” 這樣的錯誤。
父組件:
1.點擊事件進(jìn)行傳值,在template中添加組件
<button?@click="OK">給子組件發(fā)送一個消息</button>
2.父組件自定義方法將data里的數(shù)據(jù)傳遞過去:
<子組件名稱 :自定義事件="綁定的方法"></子組名稱>
data()?{
????return?{
??????自定義事件:?""
????};
??},3.引用子組件:
import 子組件名稱 from "子組件路徑";
4.注冊子組件,注冊位置與methods同級:
components:?{
????子組件名稱
??},5.在methods中寫入點擊事件
methods:?{
????OK()?{
??????this.自自定義事件?=?"傳遞過去的數(shù)據(jù)";
????}
??}子組件:
1.定義個插糟,接收渲染傳遞過來的數(shù)據(jù)
<div?v-html="自定義事件"></div>
1.接收父組件傳遞過來的值
<script>
export?default?{
??props:?["自定義事件"],
};②引用refs傳值
父組件通過refs給子組件傳值
父組件:
1.引用子組件:
import 子組件名稱 from "子組件路徑";
2.注冊子組件,注冊位置與methods同級:
components:?{
????子組件名稱
??},3.看你是什么需求了,什么需求寫在什么函數(shù)下:
周期函數(shù)(){this.$refs.父組件名稱.子組件名稱=“傳遞的參數(shù)”}
4.聲明父組件名稱:
<子組件名稱 ref=“父組件名稱”></子組件名稱>
子組件:
1.聲明子組件:
<組件名稱>子組件名稱</組件名稱>
2.將子組件名稱定義到data中:
data(){return{子組件名稱:}}2.子--->父
①屬性emit
子組件:
1.利用插值表達(dá)式顯示傳遞過去的數(shù)據(jù):
<span>{{子組件數(shù)據(jù)}}</span>2.將變量定義到data中
export?default?{
??data()?{
????return?{
??????子組件數(shù)據(jù):?"子組件的數(shù)據(jù)"
????};
??},
}3.點擊事件進(jìn)行傳值,在template中添加組件:
<button?@click="ok">OK</button>
4.向父組件傳值,在methods下定義事件:
methods:?{
????ok()?{
??????this.$emit("自定義事件",?this.子組件數(shù)據(jù));
????}
??}
};父組件:
偵聽自定義事件
1.利用插值表達(dá)式,將子組件傳遞過來的數(shù)據(jù)顯示出來
<span>{{插值表達(dá)式}}</span>2.將變量自定義到data中
export?default?{
data()?{
????return?{
??????插值表達(dá)式:?""
????};
??},
};3.父組件自定義方法偵聽子組件傳過來的值:
<子組件名稱 @自定義事件="綁定的方法"></子組名稱>
4.引用子組件:
import 子組件名稱 from "子組件路徑";
5.注冊子組件,注冊位置與methods同級:
components:?{
????子組件名稱
??},6.在methods中偵聽子組件傳過來的值:
methods:?{
????自定義事件(子組件數(shù)據(jù))?{
??????this.插值表達(dá)式?=?子組件數(shù)據(jù);
????}
??}以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue3?+?elementPlus?reset重置表單問題
這篇文章主要介紹了vue3?+?elementPlus?reset重置表單問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-05-05
前端Vue中常用rules校驗規(guī)則(輪子)如電話身份證郵箱等校驗方法例子
當(dāng)我們在開發(fā)應(yīng)用時經(jīng)常需要對表單進(jìn)行校驗,以確保用戶輸入的數(shù)據(jù)符合預(yù)期,這篇文章主要給大家介紹了關(guān)于前端Vue中常用rules校驗規(guī)則(輪子)如電話身份證郵箱等校驗方法的相關(guān)資料,需要的朋友可以參考下2023-12-12
vue uniapp 防止按鈕多次點擊的三種實現(xiàn)方式
最近的項目完成后,在性能優(yōu)化階段需要做按鈕的防止重復(fù)點擊功能,本文主要介紹了vue uniapp 防止按鈕多次點擊的三種實現(xiàn)方式,具有一定的參考價值,感興趣的可以了解一下2023-08-08

