Vue項(xiàng)目中props傳值時(shí)子組件檢測(cè)不到的問(wèn)題及解決
props傳值時(shí)子組件檢測(cè)不到
我們?cè)赩ue項(xiàng)目開發(fā)的過(guò)程中,經(jīng)常會(huì)需要在父子組件傳值,我們都知道,父子組件傳值的時(shí)候是通過(guò) props 來(lái)進(jìn)行的,但是在父組件的數(shù)據(jù)動(dòng)態(tài)改變的時(shí)候,子組件卻接收不到最新變化的數(shù)據(jù),這個(gè)時(shí)候怎么辦呢?
首先,傳值不能用駝峰命名法,因?yàn)関ue語(yǔ)法中規(guī)定HTML 中的特性名是大小寫不敏感的,所以瀏覽器會(huì)把所有大寫字符解釋為小寫字符,我們需要使用短線分隔符,例如:good-id 這樣。
然后,我們可以將數(shù)據(jù)的改變用JSON.parse(JSON.stringify(data))進(jìn)行轉(zhuǎn)化,但是官網(wǎng)上又更加直接的方法,那就是對(duì)于props接收過(guò)來(lái)的數(shù)據(jù)用watch進(jìn)行監(jiān)聽,并且,如果你想初始化的時(shí)候就進(jìn)行監(jiān)聽,可以給監(jiān)聽的屬性上加一個(gè) immediate:true
例如:
props: {
? ? personalname: {
? ? ? type: String
? ? }
? },watch: {
? ? personalname(newValue, oldValue) {
? ? ? if (newValue !== oldValue) {
? ? ? ? this.fetch(); //這里里面放你代碼的邏輯
? ? ? }
? ? },
? ? mmediate: true,
? },當(dāng)然,你如果想深層次的監(jiān)聽(如:對(duì)象,,數(shù)組等引用類型值時(shí))可以在加一個(gè) deep:true
ok,快去試試吧!
props用法和傳值問(wèn)題
props的基本用法是父組件給子組件傳輸數(shù)據(jù)和驗(yàn)證
基本用法
1.在父組件中的data中定義值
2.在子組件中使用props聲明要引用哪個(gè)值
3.父組件的template中要在子組件標(biāo)簽上綁定
4.在template模板中,要使用中劃線寫法;在script腳本中使用小駝峰

props的使用
1.靜態(tài)props
靜態(tài)即傳入的值不變化,直接在父組件中定義,子組件中使用
2.動(dòng)態(tài)props
動(dòng)態(tài)即傳入的值會(huì)變化,父組件中要?jiǎng)討B(tài)地綁定父組件的數(shù)據(jù)。
3.props驗(yàn)證
驗(yàn)證傳入的props參數(shù)的數(shù)據(jù)規(guī)格,如果不符合數(shù)據(jù)規(guī)格則發(fā)出警告,注意這個(gè)數(shù)據(jù)類型包含所有的數(shù)據(jù)類型,如基本類型和引用類型;
還可以在驗(yàn)證中加入自定義驗(yàn)證函數(shù),當(dāng)返回false時(shí)則發(fā)出警告
單向數(shù)據(jù)流:props是單向綁定的
一般來(lái)說(shuō),當(dāng)父組件的屬性變化時(shí),將傳導(dǎo)給子組件,但是反過(guò)來(lái)不會(huì)。每次父組件更新時(shí),子組件的所有 prop 都會(huì)更新為最新值。
但是,這只是限于靜態(tài)或者動(dòng)態(tài)時(shí)子組件中沒有定義局部變量去接收的情況,如果說(shuō)子組件中定義了局部變量去接收,那么父組件中的值更新時(shí)子組件是接收不到的,即子組件只能接收初始值(不管是在data中定義還是computed計(jì)算屬性定義)


第二點(diǎn),但是基本數(shù)據(jù)類型時(shí),子組件接收了父組件中的數(shù)據(jù)再進(jìn)行修改,父組件中的數(shù)據(jù)是不受影響的,也就是props的單向數(shù)據(jù)流;但是如果是對(duì)象數(shù)組這種引用類型數(shù)據(jù)的話,子組件中修改,父組件也會(huì)跟著變化的(當(dāng)然,父組件中修改子組件也會(huì)變化),原因就是它們共用一個(gè)內(nèi)存地址,相當(dāng)于淺拷貝!
解決方案:在子組件中對(duì)數(shù)據(jù)進(jìn)行局部變量接收后再進(jìn)行深拷貝??!然后用拷貝完后的數(shù)據(jù)! 看下面,一變?nèi)?/p>




總結(jié)一下props傳值的注意點(diǎn)
1.若是子組件定義局部變量去接收,則不接受父組件數(shù)據(jù)更新,即只能接收初始值
2.基本數(shù)據(jù)類型修改,子組件不會(huì)影響父組件,但是若是引用數(shù)據(jù)類型數(shù)組對(duì)象的話,兩者相互影響,共用同一個(gè)內(nèi)存地址,相當(dāng)于淺拷貝
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue中的<template>標(biāo)簽與react中的<></>標(biāo)簽區(qū)別詳解
這篇文章主要為大家介紹了vue中的<template>標(biāo)簽與react中的<></>標(biāo)簽區(qū)別詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08
vue3+ts出現(xiàn)白屏問(wèn)題的解決方法詳解
這篇文章主要為大家詳細(xì)介紹了vue3+ts出現(xiàn)白屏問(wèn)題的原因與解決方法,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-03-03
vue3無(wú)法顯示element-plus問(wèn)題及解決
這篇文章主要介紹了vue3無(wú)法顯示element-plus問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03
在Vue 3中使用OpenLayers讀取WKB數(shù)據(jù)并顯示圖形效果
WKB作為一種緊湊的二進(jìn)制格式,在處理和傳輸空間數(shù)據(jù)時(shí)具有明顯優(yōu)勢(shì),本文介紹了如何在Vue 3中使用OpenLayers讀取WKB格式的空間數(shù)據(jù)并顯示圖形,感興趣的朋友一起看看吧2024-12-12

