国产探花免费观看_亚洲丰满少妇自慰呻吟_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])    }

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

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

圖片精選

主站蜘蛛池模板: 额敏县| 日照市| 马尔康县| 启东市| 延庆县| 措美县| 余庆县| 烟台市| 内江市| 洱源县| 峨眉山市| 临西县| 桓台县| 乃东县| 金堂县| 五峰| 湖州市| 通化县| 怀柔区| 阳山县| 灯塔市| 晋城| 建瓯市| 和田县| 定州市| 元江| 河北省| SHOW| 邢台县| 永济市| 承德市| 中卫市| 连江县| 东乡县| 东至县| 沙河市| 晋中市| 阿城市| 安福县| 汝州市| 增城市|