国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

Vue 報錯TypeError: this.$set is not a function 的解決方法

2024-05-06 15:27:17
字體:
來源:轉載
供稿:網友

報錯場景:將APi中得到的response數據,用Vue$set()使數據動態響應

報錯代碼:

 methods: {  textTranslate: function (text, to) {    $.ajax({    url: 'http://openapi.youdao.com/api',    type: 'post',    dataType: 'jsonp',    data: {     q: text,     appKey: this.appKey,     salt: this.salt,     from: this.from,     to: to,     sign: md5(this.appKey + text + this.salt + this.key)    },    success: function (data) {     this.$set(this.$data, 'translatedText', data.translation[0])    }   })  } }

報錯原因:這里的this指向的不是VueModel,

解決方法1:在執行函數中定義指向Model的變量 let vm = this ,用該變量替代this

 methods: {  textTranslate: function (text, to) {   let vm = this   $.ajax({    url: 'http://openapi.youdao.com/api',    type: 'post',    dataType: 'jsonp',    data: {     q: text,     appKey: this.appKey,     salt: this.salt,     from: this.from,     to: to,     sign: md5(this.appKey + text + this.salt + this.key)    },    success: function (data) {     vm.$set(vm.$data, 'translatedText', data.translation[0])    }   })  } }

解決方法2:將。siccess改為箭頭函數的寫法,這樣子箭頭函數里的this其實是指向VueModel的,這樣子用this看不會報錯了

success: (data) => {     this.$set(this.$data, 'translatedText', data.translation[0])    }

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持錯新站長站。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 巴林左旗| 九龙县| 梁山县| 伊宁县| 宜城市| 晋城| 乌拉特前旗| 治县。| 南平市| 黑水县| 永川市| 渭南市| 新津县| 武夷山市| 兴文县| 金湖县| 台南市| 嘉鱼县| 望都县| 三穗县| 北宁市| 洞口县| 连山| 安阳县| 万宁市| 宁夏| 咸宁市| 澎湖县| 班戈县| 英吉沙县| 教育| 略阳县| 永顺县| 泉州市| 乳山市| 乌鲁木齐市| 丰顺县| 垣曲县| 泰来县| 嵊州市| 兴和县|