色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

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

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

瀏覽:2日期: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
主站蜘蛛池模板: 青草欧美 | 国产美女精品一区二区三区 | 一级在线视频 | 九七在线视频 | 国产成人综合亚洲一区 | 日本一区二区三区国产 | 国产精品久久久久久久久久直 | 日韩毛片免费视频一级特黄 | 2021国产精品自拍 | 欧美日本一道道一区二区三 | 男女配种猛烈免费视频 | 中日韩一级片 | 成人黄色免费观看 | 在线亚洲精品国产波多野结衣 | 99国产成人高清在线视频 | 国产成人小视频在线观看 | 亚洲 欧美 在线观看 | 欧美一级毛片免费大片 | 国产欧美另类久久久精品免费 | 中文精品久久久久国产网址 | 特级a毛片 | 台湾一级特黄精品大片 | 免费高清国产 | 午夜国产理论 | 国产在线拍揄自揄视精品不卡 | 日本69色视频在线观看 | 久久精品国产亚洲aa | 色伊人国产高清在线 | 成年人毛片视频 | 欧美成人免费在线观看 | 欧美国产日韩久久久 | 91手机看片国产福利精品 | 欧美亚洲免费 | 亚洲一级黄色毛片 | 91成年人 | 国产视频合集 | 美女黄色在线看 | 免费在线精品视频 | 国产成人一区二区在线不卡 | 97在线播放| www成人在线观看 |