这篇文章主要介绍了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])
    }

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

最新资讯
蚂蚁集团造富盛宴:“泰山会”大佬,赵薇、苗圃都是赢家

蚂蚁集团造富盛宴:“泰

马云背后的“豪华朋友圈”通过云锋基金等机构的参与成
图灵奖、京都奖得主共话自动驾驶:未来5至10年会超过人类吗?

图灵奖、京都奖得主共

对于构建复杂系统来说,采用人工智能技术是有必要的,但人
美股科技股遭遇“黑色星期五”:机构投资者现在看好这个机会

美股科技股遭遇“黑色

面对将持续震荡的欧美市场,哪里还能是投资热土?放眼全球
上帝粒子是什么?

上帝粒子是什么?

上帝粒子是什么?想解答这个问题,首先需要提及一个名词—
我原想研究干净的水,结果在厕所里越走越远……

我原想研究干净的水,结

厕所的覆盖率逐渐在增加,那么反映到我们的儿童死亡率上
达尔文之过:人类真的和其他生物平等吗?

达尔文之过:人类真的和

人类在自然界中的地位,真的如达尔文与赫胥黎认为的那样
最新文章
详解Vue的ref特性的使用

详解Vue的ref特性的使

这篇文章主要介绍了详解Vue的ref特性的使用,文中通过
vue学习笔记之slot插槽基本用法实例分析

vue学习笔记之slot插

这篇文章主要介绍了vue学习笔记之slot插槽基本用法,结
vue跳转方式(打开新页面)及传参操作示例

vue跳转方式(打开新页

这篇文章主要介绍了vue跳转方式(打开新页面)及传参操作,
vue学习笔记之过滤器的基本使用方法实例分析

vue学习笔记之过滤器

这篇文章主要介绍了vue学习笔记之过滤器的基本使用方
js获取本日、本周、本月的时间代码

js获取本日、本周、本

本篇文章给大家分享的内容是利用js如何获取本日、本周
node crawler如何添加promise支持

node crawler如何添加

这篇文章主要介绍了node crawler如何添加promise支持,