Vue將props值實(shí)時(shí)傳遞 并可修改的操作
我們都知道props值是只讀的,子組件內(nèi)不可直接修改,會(huì)報(bào)錯(cuò)滴
但是很多時(shí)候這個(gè)值是需要子組件主動(dòng)修改的,一般我們會(huì)使用this.$emit()去修改,但比較麻煩
下面這種方式可以實(shí)現(xiàn):
1、父組件實(shí)時(shí)修改props值時(shí),子組件可以接收到改變
2、子組件可主動(dòng)修改該值
<div>{{RealValue}}</div>
props: [ "value" ],
watch: {
value (v) {
this.RealValue = v
}
},
data () {
return {
RealValue: this.value
}
}
原理很簡(jiǎn)單,就是使用一個(gè)RealValue作為實(shí)際顯示的參數(shù),并且使用watch實(shí)時(shí)把value值傳給他
PS:這里的值是字符串格式,如果value是對(duì)象或者數(shù)組,watch處要寫成:
watch: {
value:{
deep: true,
handler(v) {
this.RealValue = v
}
}
},
補(bǔ)充知識(shí):vue組件內(nèi)數(shù)值做watch監(jiān)聽,首次監(jiān)聽不到的問(wèn)題
在vue中會(huì)使用很多子組件,有時(shí)因?yàn)榻M件的類型等原因會(huì)導(dǎo)致數(shù)據(jù)監(jiān)聽不到的情況,下面列舉幾種問(wèn)題和解決方法
子組件內(nèi)數(shù)據(jù)首次監(jiān)聽不到時(shí),可以使用【immediate】方法,其值是true或false;immediate:true代表如果在 wacth 里聲明了之后,就會(huì)立即先去執(zhí)行里面的handler方法
watch:{
uploadImageUrl:{
immediate:true,
handler:function(newval){
this.uploadShowImageUrl = newval;
}
}
},
子組件的深度監(jiān)聽函數(shù)【deep】,其值是true或false;確認(rèn)是否深入監(jiān)聽。deep的意思就是深入觀察,監(jiān)聽器會(huì)一層層的往下遍歷,給對(duì)象的所有屬性都加上這個(gè)監(jiān)聽器(受現(xiàn)代 JavaScript 的限制 (以及廢棄 Object.observe),Vue 不能檢測(cè)到對(duì)象屬性的添加或刪除)
watch:{
uploadImageUrl:{
deep:true,
handler:function(newval){
this.uploadShowImageUrl = newval;
}
}
},
給組件內(nèi)的props為對(duì)象的數(shù)據(jù)設(shè)置默認(rèn)值
如果prop中接收的數(shù)據(jù)為對(duì)象或者數(shù)組類型,是不可以像字符串等【default:''】直接指定default值的,會(huì)報(bào)【Invalid default value for prop “defaultProp”: Props with type Object/Array must use a factory function to return the default value.】錯(cuò)誤,修正方法如下
defaultProp: {
type: Object,
default: function(){
return {
children: 'children',
label: 'name'
}
}
},
以上這篇Vue將props值實(shí)時(shí)傳遞 并可修改的操作就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Vue請(qǐng)求JSON Server服務(wù)器數(shù)據(jù)的實(shí)現(xiàn)方法
這篇文章主要介紹了Vue請(qǐng)求JSON Server服務(wù)器數(shù)據(jù)的實(shí)現(xiàn)方法,需要的朋友可以參考下2018-11-11
vue從倉(cāng)庫(kù)state中取不到數(shù)據(jù)的問(wèn)題
這篇文章主要介紹了vue從倉(cāng)庫(kù)state中取不到數(shù)據(jù)的問(wèn)題及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04
vue中使用mixins/extends傳入?yún)?shù)的方式
這篇文章主要介紹了vue中使用mixins/extends傳入?yún)?shù)的方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-05-05
vue拖拽組件vuedraggable使用說(shuō)明詳解
這篇文章主要為大家詳細(xì)介紹了vue拖拽組件vuedraggable的使用說(shuō)明,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-04-04
vue組件和iframe頁(yè)面的相互傳參問(wèn)題及解決
這篇文章主要介紹了vue組件和iframe頁(yè)面的相互傳參問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-05-05
vue移動(dòng)端實(shí)現(xiàn)手指滑動(dòng)效果
這篇文章主要為大家詳細(xì)介紹了vue移動(dòng)端實(shí)現(xiàn)手指滑動(dòng)效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-06-06

