亚洲免费在线视频-亚洲啊v-久久免费精品视频-国产精品va-看片地址-成人在线视频网

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

解決vue偵聽器watch,調用this時出現undefined的問題

瀏覽:3日期:2022-11-08 13:14:44

watch偵聽器中,我們要將新的值賦給this.a出錯

watch: { value: (newV, oldV) => { this.a = newV; }}

這里報錯undefined,這里錯誤的原因是不能寫成箭頭函數。寫成箭頭函數后,this會取上下文,而不是組件里面的this了,正確寫法為:

watch: { value: function(newV, oldV) { this.a = newV; }}

如下圖:

解決vue偵聽器watch,調用this時出現undefined的問題

看考鏈接:https://cn.vuejs.org/v2/api/#watch

PS:好吧,雖然問題可以解決,但是具體為什么不能寫成箭頭函數,講實話,我現在也不懂,知道原理的可以給我評論,非常感謝。

來自yyf994的評論解答:

var app = new Vue({ el: ’#app’, data: { a: 1 }, watch: { a:()=> { console.log(this) } }, methods: { onClick() { this.a++; } } })

在babel 編譯后是這樣子的

'use strict'; var _this = void 0; var app = new Vue({ el: ’#app’, data: { a: 1 }, watch: { a: function a() { console.log(_this); } }, methods: { onClick: function onClick() { this.a++; } }});

因為箭頭函數 的 函數體內的this對象,就是定義時所在的對象,而不是使用時所在的對象。

補充知識:vue watch用法和沒反應的原因 =>看看下面是不是還有一個watch

我就廢話不多說了,大家還是直接看代碼吧~

watch: { stop: function(newVal, old){ //非josn用法 console.log(newVal) }, ’form.fdnDct’: function(newVal, old){ //josn用法 console.log(newVal) }, } //這也是一種用法 watch: { ’browse_integral_info.buy’:’RMB’, //購買積分轉化成人民幣 ’browse_integral_info.give’:’GIVE’, //完成邀請瀏覽任務贈送 ’bargain_integral_info.give’:’BARGAINGIVE’, deep:true, }, methods: { RMB: function(){ this.RMBs = this.browse_integral_info.buy/100 }, },

以上這篇解決vue偵聽器watch,調用this時出現undefined的問題就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Vue
主站蜘蛛池模板: 毛片网站观看 | 一区二区亚洲精品 | 国产精品国产三级国产专播 | 国产成人a大片大片在线播放 | 久久精品免费播放 | 91桃色成人免费 | 久久精选视频 | 波多野结衣在线视频免费观看 | 武松大战潘金莲三级在线 | 国产高清第一页 | 欧美国产亚洲一区 | 精品一区二区三区在线播放 | 欧美精品一区二区在线观看 | 国产成人福利视频网站 | 国产夫妇精品自在线 | 这里只有精品国产 | 亚洲天堂精品在线观看 | 中文字幕水野优香在线网在线 | 日本 片 成人 在线 日本68xxxxxxxxx老师 | 欧美成人精品欧美一级乱黄 | 亚洲国产一区在线精选 | 国产精品久久久久久福利 | 好看毛片| 一级毛片aaaaaa视频免费看 | 久久久毛片免费全部播放 | 男女免费观看在线爽爽爽视频 | 香港aa三级久久三级老师 | 伊人成人在线视频 | 国产精品久久久久毛片 | 亚州免费| 国产午夜精品久久久久免费视 | 亚洲一区二区三区高清 | 国产亚洲欧美一区二区三区 | 久久免费99精品久久久久久 | 欧美一级视频在线观看 | 米奇777色狠狠8888影视 | 国产精品久久久久久福利漫画 | 国产一级片视频 | 九九热播视频 | 欧美激情久久久久久久大片 | 国产黄色a三级三级三级 |