报错场景:将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])
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
继续阅读与本文标签相同的文章
-
每分钟进出车辆2.5台 智能立体车库解锁停车难
2026-05-19栏目: 教程
-
一文了解机器学习必学10大算法
2026-05-19栏目: 教程
-
开一家线上外卖门店选址要注意哪些因素?
2026-05-19栏目: 教程
-
信院人的APP,你get到了吗?
2026-05-19栏目: 教程
-
对话FILA姚伟雄:安踏赋予独立性,未来坚持做直营
2026-05-19栏目: 教程
