当前位置: 移动技术网 > IT编程>脚本编程>vue.js > Vue 报错TypeError: this.$set is not a function 的解决方法

Vue 报错TypeError: this.$set is not a function 的解决方法

2019年01月04日  | 移动技术网IT编程  | 我要评论

红旗颂纯音乐,验收房子注意事项,优装保

报错场景:将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])
    }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网