亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

Vue將props值實時傳遞 并可修改的操作

瀏覽:71日期:2022-12-11 18:02:24

我們都知道props值是只讀的,子組件內不可直接修改,會報錯滴

但是很多時候這個值是需要子組件主動修改的,一般我們會使用this.$emit()去修改,但比較麻煩

下面這種方式可以實現:

1、父組件實時修改props值時,子組件可以接收到改變

2、子組件可主動修改該值

<div>{{RealValue}}</div> props: [ 'value' ], watch: { value (v) { this.RealValue = v } }, data () { return { RealValue: this.value } }

原理很簡單,就是使用一個RealValue作為實際顯示的參數,并且使用watch實時把value值傳給他

PS:這里的值是字符串格式,如果value是對象或者數組,watch處要寫成:

watch: { value:{ deep: true, handler(v) { this.RealValue = v } } },

補充知識:vue組件內數值做watch監聽,首次監聽不到的問題

在vue中會使用很多子組件,有時因為組件的類型等原因會導致數據監聽不到的情況,下面列舉幾種問題和解決方法

子組件內數據首次監聽不到時,可以使用【immediate】方法,其值是true或false;immediate:true代表如果在 wacth 里聲明了之后,就會立即先去執行里面的handler方法

watch:{ uploadImageUrl:{ immediate:true, handler:function(newval){ this.uploadShowImageUrl = newval; } }},

子組件的深度監聽函數【deep】,其值是true或false;確認是否深入監聽。deep的意思就是深入觀察,監聽器會一層層的往下遍歷,給對象的所有屬性都加上這個監聽器(受現代 JavaScript 的限制 (以及廢棄 Object.observe),Vue 不能檢測到對象屬性的添加或刪除)

watch:{ uploadImageUrl:{ deep:true, handler:function(newval){ this.uploadShowImageUrl = newval; } }},

給組件內的props為對象的數據設置默認值

如果prop中接收的數據為對象或者數組類型,是不可以像字符串等【default:’’】直接指定default值的,會報【Invalid default value for prop “defaultProp”: Props with type Object/Array must use a factory function to return the default value.】錯誤,修正方法如下

defaultProp: { type: Object, default: function(){ return { children: ’children’, label: ’name’ } }},

以上這篇Vue將props值實時傳遞 并可修改的操作就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Vue
相關文章:
主站蜘蛛池模板: 亚洲欧美日韩成人 | 日本一级特黄完整大片 | 日韩黄色大片免费看 | 国产成人v爽在线免播放观看 | 一区二区三区福利视频 | 欧美黄色大全 | 欧美三级影视 | 中文字幕日韩欧美一区二区三区 | 亚洲第一免费 | 久久爱伊人| 99草在线观看| 在线高清视频观看vvvv | 免费黄视频在线观看 | 色综合久久久久久中文网 | 黄色一级录像 | 国产精品视频福利一区二区 | 毛片毛片毛片 | 一区二区精品在线观看 | 草草青青| 五月天婷婷综合 | 亚洲小视频网站 | 欧美一区二区三区精品国产 | 激情在线视频 | 国产精品二区三区免费播放心 | 国产大秀视频在线一区二区 | 成人精品一区二区久久 | 色香欲综合成人免费视频 | 欧美色爱综合网 | 久久亚洲在线 | 国产一区二区精品人妖系列 | 色优久久| 无码精品一区二区三区免费视频 | 日韩永久免费视频 | 91九色porn偷拍在线 | 精品视频在线观看你懂的一区 | 日韩黄色大片免费看 | 国产精品白丝喷水在线观看 | 国产精品青草久久久久福利99 | 成人网免费看 | 一级毛片免费观看久 | 中文精品爱久久久国产 |