微信小程序的this和that的用法

在微信小程序中我们一般通过以下方式来修改data中的数据

this.setData({
      index1: e.detail.value
    })

比如在函数里面修改数据

bindFaChange1: function (e) {
    this.setData({
      index1: e.detail.value
    })
  }

但是当我们通过wx.request请求网络数据成功后绑定数据时候报以下错误

this.setData is not a function

代码如下:

doCalc:function(){
    wx.request({
      url: url,
      method:'POST',
      header: {
        'content-type': 'application/json' // 默认值
      },
      success: function (res) {
        if (res.data.code == 0){
          this.setData({
            maxCount: res.data.maxCount
          });
        }
      }
    })
  }

这是因为this作用域指向问题 ,success函数实际是一个闭包 , 无法直接通过this来setData

那么需要怎么修改呢?

我们通过将当前对象赋给一个新的对象

var _this = this;

然后使用_this 来setData就行了

完整代码

doCalc:function(){
    var _this = this;
    wx.request({
      url: url,
      method:'POST',
      header: {
        'content-type': 'application/json' // 默认值
      },
      success: function (res) {
        if (res.data.code == 0){
          _this.setData({
            maxCount: res.data.maxCount
          });
        }
      }
    })
  }

你可能感兴趣的:(微信小程序的this和that的用法)