Vue中的Props(不可變狀態(tài))
組件接受的選項(xiàng)大部分與Vue實(shí)例一樣,而選項(xiàng)props是組件中非常重要的一個(gè)選項(xiàng)。在 Vue 中,父子組件的關(guān)系可以總結(jié)為 props down, events up。父組件通過(guò) props 向下傳遞數(shù)據(jù)給子組件,子組件通過(guò) events 給父組件發(fā)送消息。接下來(lái)通過(guò)本文給大家介紹Vue中Props,一起看看吧!

單向數(shù)據(jù)流
所有的 prop 都使得其父子 prop 之間形成了一個(gè)單向下行綁定:父級(jí) prop 的更新會(huì)向下流動(dòng)到子組件中,但是反過(guò)來(lái)則不行。這樣會(huì)防止從子組件意外改變父級(jí)組件的狀態(tài),從而導(dǎo)致你的應(yīng)用的數(shù)據(jù)流向難以理解。
額外的,每次父級(jí)組件發(fā)生更新時(shí),子組件中所有的 prop 都將會(huì)刷新為最新的值。這意味著你不應(yīng)該在一個(gè)子組件內(nèi)部改變 prop。如果你這樣做了,Vue 會(huì)在瀏覽器的控制臺(tái)中發(fā)出警告。
問(wèn)題
下面簡(jiǎn)要說(shuō)一下上面發(fā)生的警告現(xiàn)象,或許大多數(shù)人都遇到過(guò).
使用場(chǎng)景
父組件
<BackLogModal :isModalOpen="isModalOpen" @closeModal="handleCloseModal"> </BackLogModal>
- BackLogModal為一個(gè)彈窗組件,通過(guò)isModalOpen決定彈窗的開(kāi)閉狀態(tài)
- 傳入的isModalOpen是父組件的一個(gè)變量,類(lèi)型為boolean
- closeModal監(jiān)聽(tīng)子組件派發(fā)的自定義事件closeModal
子組件
// 使用了typescript
export default class BackLogModal extends Vue {
@Prop()
private isModalOpen: boolean;
private handleConfirm(): void {
this.$Message.info('Clicked ok');
this.$emit('closeModal');
}
private handleClose(): void {
this.$Message.info('Clicked cancal');
this.$emit('closeModal');
}
}
- 通過(guò)@Prop()注解獲取父組件傳遞過(guò)來(lái)的isModalOpen屬性
- 頁(yè)面 通過(guò)v-model與屬性isModalOpen進(jìn)行綁定
- 由于彈窗組件在關(guān)閉時(shí)會(huì)自動(dòng)設(shè)置isModalOpen的值為false,這里直接修改的就是父組件傳入的isModalOpen屬性,由于props屬性是單向數(shù)據(jù)流,具有不可變狀態(tài),這是頁(yè)面就會(huì)拋出警告
解決問(wèn)題
export default class BackLogModal extends Vue {
private isOpen: boolean = false;
@Prop()
private isModalOpen: boolean;
@Watch('isModalOpen')
private watchModalOpen(newVal: boolean, oldVal: boolean) {
console.log(newVal, oldVal);
if (newVal !== oldVal) {
this.isOpen = newVal;
}
}
private handleConfirm(): void {
this.$Message.info('Clicked ok');
this.$emit('closeModal');
}
private handleClose(): void {
this.$Message.info('Clicked cancal');
this.$emit('closeModal');
}
}
- 定義一個(gè)子組件私有變量isOpen與頁(yè)面彈窗就行綁定
- 使用@Watch('isModalOpen')監(jiān)聽(tīng)父組件傳入的isModalOpen屬性,一旦值發(fā)生改變,便更新本地變量isOpen,確保彈窗的正常的打開(kāi)與關(guān)閉
以上所述是小編給大家介紹的Vue中的Props(不可變狀態(tài)),希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
vue對(duì)于低版本瀏覽器兼容問(wèn)題的解決思路
很多時(shí)候使用vue開(kāi)發(fā)的項(xiàng)目,由于無(wú)法在低版本瀏覽器上運(yùn)行,所以需要解決下,下面這篇文章主要給大家介紹了關(guān)于vue對(duì)于低版本瀏覽器兼容問(wèn)題的解決思路,需要的朋友可以參考下2023-02-02
vue3?ts編寫(xiě)echart是tooltip無(wú)法展示的解決
這篇文章主要介紹了vue3?ts編寫(xiě)echart是tooltip無(wú)法展示的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-10-10
vue等兩個(gè)接口都返回結(jié)果再執(zhí)行下一步的實(shí)例
這篇文章主要介紹了vue等兩個(gè)接口都返回結(jié)果再執(zhí)行下一步的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-09-09
如何搭建一個(gè)完整的Vue3.0+ts的項(xiàng)目步驟
這篇文章主要介紹了如何搭建一個(gè)完整的Vue3.0+ts的項(xiàng)目步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-10-10
Vue常見(jiàn)報(bào)錯(cuò)以及解決方案實(shí)例總結(jié)
最近做了一個(gè)比較老的vue項(xiàng)目,啟動(dòng)居然各種報(bào)錯(cuò),下面這篇文章主要給大家介紹了關(guān)于Vue常見(jiàn)報(bào)錯(cuò)以及解決方案的相關(guān)資料,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下2022-07-07
vue中img src 動(dòng)態(tài)加載本地json的圖片路徑寫(xiě)法
這篇文章主要介紹了vue中的img src 動(dòng)態(tài)加載本地json的圖片路徑寫(xiě)法,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-04-04
淺談vite和webpack的性能優(yōu)化和區(qū)別
本文主要介紹了淺談vite和webpack的區(qū)別,從性能優(yōu)化的幾個(gè)方便講解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-05-05
vue3響應(yīng)式Proxy與Reflect的理解及基本使用實(shí)例詳解
這篇文章主要為大家介紹了vue3響應(yīng)式Proxy與Reflect的理解及基本使用實(shí)例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08

