日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

Vue中的this.$options.data()和this.$data用法說明

瀏覽:25日期:2022-12-27 16:50:30

問題

項目里遇到一個問題,用this.$options.data()重置組件data時,data()里用this獲取的props或method都為undefined,代碼簡化如下:

export default { props: { P: Object }, data () { return { A: {a: this.methodA }, B: this.P }; }, methods: { resetData () { // 更新時調用 Object.assign(this.$data, this.$options.data()); // 有問題!!! }, methodA () { // do sth. }, methodB () { // 通過用戶操作調用 this.A.a && this.A.a(); // this.A.a is undefined, this.B is undefined!?。? } }}

調用resetData()之后,再調用methodB()時,this.A.a和this.B是undefined。

解決

resetData里這樣寫:

resetData () { // 更新時調用 Object.assign(this.$data, this.$options.data.call(this));}

原因

和Vue實例的初始化相關。(源碼version2.6.10)

1、new Vue的時候傳了一個對象,把該對象記為options,Vue將options中自定義的屬性和Vue構造函數中定義的屬性合并為vm.$options,vm.$options.data()中的this指向vm.$options,而methodA和B并沒有直接掛在vm.$options下,所以this.methodA和this.B為undefined。

// 創建一個vue實例const options = { customOption: ’foo’, data () { A: this.methodA }, methods: { methodA () {} }, created: function () { console.log(this.$options.customOption) // => ’foo’ }};new Vue(options); // src/core/instance/init.jsinitMixin (Vue: Class<Component>) { const vm: Component = this // ... vm.$options = mergeOptions( resolveConstructorOptions(vm.constructor), options || {}, vm ) // ...}

2、然后將vm.$options.data映射到vm._data,使得可以通過vm._data訪問數據,在映射過程中,通過call將data()的this指向當前的實例vm,并將data()的執行結果返回,因為prop和methods的初始化在data之前,所以這時vm上已有_props和_methods,可以拿到this.methodA和this.B。(vm.key如何實現vm._props.key效果見3)。

// src/core/instance/state.jsinitState (vm: Component) { // ... const opts = vm.$options if (opts.props) initProps(vm, opts.props) if (opts.methods) initMethods(vm, opts.methods) if (opts.data) { initData(vm) // 里面通過getData(data, vm)改變this } // ...} getData (data: Function, vm: Component): any { // ... try { return data.call(vm, vm) // this替換為vm } // ...}

3、上面把屬性映射到了vm._data里,可以通過vm._data.A訪問數據,Vue再通過一個代理方法使得vm.A可以直接訪問A。

// src/core/instance/state.jsproxy(vm, `_data`, key); proxy (target: Object, sourceKey: string, key: string) { sharedPropertyDefinition.proxyget = function proxyGetter () { return this[sourceKey][key] } sharedPropertyDefinition.set = function proxySetter (val) { this[sourceKey][key] = val } Object.defineProperty(target, key, sharedPropertyDefinition)}

總結

data()中若使用了this來訪問props或methods,在重置$data時,注意this.$options.data()的this指向,最好使用this.$options.data.call(this)。

以上這篇Vue中的this.$options.data()和this.$data用法說明就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Vue
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
色爱综合网欧美| 日韩精品免费一区二区三区| 韩国三级一区| 色在线中文字幕| 日本激情一区| 国产在线观看www| 日韩亚洲一区在线| 久久精品卡一| 精品在线91| 亚洲激情二区| 视频一区免费在线观看| 久久99伊人| 色综合视频一区二区三区日韩| 免费精品视频在线| 蜜臀av亚洲一区中文字幕| 在线看片一区| 日本欧美一区| 国产精品国码视频| 国产成人免费av一区二区午夜| 成人一区不卡| 欧美va天堂在线| 亚洲三级观看| 国产乱码精品一区二区亚洲| 久久婷婷国产| 日韩国产网站| 先锋影音久久久| 亚洲欧美在线综合| 欧美日韩一区二区高清| 精品日本视频| 久久伦理在线| 亚洲精一区二区三区| 国产欧美欧美| 福利一区在线| 欧美精选一区二区三区| 亚洲网址在线观看| 久久99视频| 久久亚洲国产| 日韩精品久久久久久| 麻豆久久久久久| 四虎影视精品| 天堂俺去俺来也www久久婷婷| 麻豆一区二区三| 久久精品高清| 91精品视频一区二区| 国产盗摄——sm在线视频| 狠狠干成人综合网| 国产精品jk白丝蜜臀av小说| 国产不卡精品| 久久福利一区| 老司机免费视频一区二区| 99成人在线视频| 亚洲精品伦理| 亚洲啊v在线| 日韩视频1区| 婷婷综合六月| 欧美亚洲自偷自偷| 久久久久免费av| 91成人在线精品视频| av免费不卡国产观看| 蜜臀av在线播放一区二区三区| 久久久91麻豆精品国产一区| 黄色免费成人| 国产精品porn| 久久夜色精品| 国产69精品久久| 亚洲综合专区| 日韩欧美一区二区三区免费观看| 国产美女精品| 国产+成+人+亚洲欧洲在线| 久久大逼视频| 亚洲一区资源| 五月亚洲婷婷 | 五月天久久久| 国产精品xxx| 亚洲欧美日本日韩| 国产精品黑丝在线播放| 日本中文字幕不卡| 久久久9色精品国产一区二区三区| 国产视频一区二| 伊人久久婷婷| 成人一区而且| 国产欧美日韩一区二区三区四区| 红桃视频欧美| 韩国三级一区| 精品国产一级| 久久精品xxxxx| 亚洲欧美日韩综合国产aⅴ| 毛片在线网站| 日本不卡高清视频| 亚洲作爱视频| 私拍精品福利视频在线一区| 免费一区二区三区在线视频| 亚洲精品乱码| 国产亚洲精品v| 久久精品影视| 国产中文在线播放| 美女视频黄免费的久久| 97久久中文字幕| 水蜜桃久久夜色精品一区的特点| 日本国产精品| 国产aⅴ精品一区二区四区| 欧美亚洲tv| 亚洲精品自拍| 国内精品福利| 色老板在线视频一区二区| 国产精品99久久精品| 麻豆精品视频在线| 欧美日韩一区二区国产| 婷婷综合成人| 免费一区二区视频| 在线亚洲精品| 91九色精品国产一区二区| 国产 日韩 欧美一区| 国产精品99视频| 久久只有精品| 免费看一区二区三区| 国产精品啊啊啊| 国产欧美日韩免费观看| 亚洲色图综合| 亚欧洲精品视频在线观看| 久久亚洲电影| 日韩中文字幕不卡| 男女男精品网站| 亚洲一级淫片| 日本aⅴ精品一区二区三区| 亚洲精品自拍| 91亚洲精品在看在线观看高清| 日本成人在线视频网站| 日本特黄久久久高潮| 国产欧美日韩一区二区三区四区| 国产精品v一区二区三区| 福利一区二区三区视频在线观看| 中文在线а√在线8| 国产传媒在线观看| av亚洲一区二区三区| 91精品国产调教在线观看| 激情欧美丁香| 亚洲在线观看| 中文字幕视频精品一区二区三区| 亚洲人妖在线| 欧美另类中文字幕| 久久97视频| 久久精品亚洲人成影院 | 欧美日韩一区二区高清| 欧美激情综合| 国语精品一区| 亚洲黑丝一区二区| 午夜在线一区| 日本精品在线播放| 麻豆91精品视频| 日韩中文在线播放| 午夜在线一区二区| 久久国产三级精品| 成人精品国产亚洲| 欧美午夜不卡| 欧美三区不卡| 欧美激情国产在线| jiujiure精品视频播放| 亚州欧美在线| 精品国产麻豆| 欧美日中文字幕| 天海翼亚洲一区二区三区| 久久亚洲国产精品尤物| jiujiure精品视频播放| 日本强好片久久久久久aaa| 视频在线不卡免费观看| 亚洲女人av| 麻豆一区二区三区| 亚洲大全视频| 国产欧美日本| 亚洲二区视频| 日本va欧美va精品| 国产精品久久久久久久久久10秀 | 日韩中文首页| 天堂av在线一区| 欧美成人aaa| 午夜久久久久| 国产三级精品三级在线观看国产| 国产亚洲一区二区手机在线观看 | 日韩1区2区3区| 青青久久av| 欧美精品国产| 亚洲激情五月| 国产日韩欧美| 欧美 日韩 国产精品免费观看| 日本成人手机在线| 精品久久福利| 美女精品一区| 国产一区不卡| 日本在线成人| 久久久久国产一区二区| 日韩免费精品| 黄色不卡一区| 国产精品日本一区二区不卡视频 | 欧美激情麻豆| av不卡在线| 国产精品黑丝在线播放| 色综合视频一区二区三区日韩 | 国产精品天天看天天狠| 亚洲精品一区二区在线看|