码迷,mamicode.com
首页 > 微信 > 详细

微信小程序 this.setData is not a function

时间:2018-01-22 17:32:55      阅读:291      评论:0      收藏:0      [点我收藏+]

标签:clear   detail   disable   style   函数   script   gpo   blog   没有   

  在一般的函数中:

1 bindFaChange1: function (e) {
2     console.log(‘picker发送选择改变,携带值为‘, e.detail.value)
3     this.setData({
4       index1: e.detail.value
5     })
6   }

  this.setData是正确的。

  但当在函数中有个请求(wx.request)时:

 1 formSubmit: function (e) {
 2     wx.request({
 3       method: ‘POST‘,
 4       header: header,
 5       url: url,
 6       dataType: ‘json‘,
 7      success: function (res) {
 8            this.setData({
 9               data1: true
10             })
11       }
12     })
13 }

  或者执行定时任务时候:

 1 var si = setInterval(function () {
 2         that.setData({
 3           sendVerifyingCodeText: curCount + ‘秒后重新获取‘
 4         });
 5         that.setData({
 6           sendSmsCodeDisable: true
 7         });
 8         curCount--;
 9         if (curCount <= 0) {
10           that.setData({
11             sendSmsCodeDisable: false
12           }),
13           clearInterval(si);
14         }
15       }, 1000);

  这样会报错误:this.setData is not a function.

  这个在新的函数内的this代表的是这个函数体,所有是没有this.setData。这个类似java中的this指的是当前对象,但是javascript是以函数为主体的,所以就是this在函数内部就当前函数。修改未:

  解决方法就是 :在请求(wx.request)或者新的非当前js的方法外面添加:var that=this;然后用:

1 that.setData({
2               data1: true
3             })

 

微信小程序 this.setData is not a function

标签:clear   detail   disable   style   函数   script   gpo   blog   没有   

原文地址:https://www.cnblogs.com/lcngu/p/8329490.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!