Vue 报错TypeError: this.$set is not a function 的解决方法
更新时间:2018年12月17日 11:17:15 作者:做一个有知识的流氓
这篇文章主要介绍了Vue 报错TypeError: this.$set is not a function 的解决方法,分享给大家,需要的朋友们下面随着小编来一起学习学习吧
报错场景:将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项目报错:Uncaught SyntaxError: Unexpected token <
- 解决vue安装less报错Failed to compile with 1 errors的问题
- Vue.js报错Failed to resolve filter问题的解决方法
- Vue报错:Uncaught TypeError: Cannot assign to read only property’exports‘ of object’#<Object>‘的解决方法
- vue踩坑记-在项目中安装依赖模块npm install报错
- VUE 项目在IE11白屏报错 SCRIPT1002: 语法错误的解决
- Vue 解决通过this.$refs来获取DOM或者组件报错问题
- Vue——解决报错 Computed property "****" was assigned to but it has no setter.
- vue-cli 打包后提交到线上出现 "Uncaught SyntaxError:Unexpected token" 报错
- Vue实战之项目开发时常见的几个错误汇总
相关文章
利用Vue-draggable组件实现Vue项目中表格内容的拖拽排序
这篇文章主要介绍了利用Vue-draggable组件实现Vue项目中表格内容的拖拽排序,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧2019-06-06
最新评论