这篇文章主要为大家展示了“Vue报TypeError: this.$set is not a function错误怎么办”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Vue报TypeError: this.$set is not a function错误怎么办”这篇文章吧。
创新互联-专业网站定制、快速模板网站建设、高性价比孙吴网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式孙吴网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖孙吴地区。费用合理售后完善,十余年实体公司更值得信赖。
报错场景:将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]) }
以上是“Vue报TypeError: this.$set is not a function错误怎么办”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!