小程序开发踩坑之旅

关于this的绑定

这个应该也不算是小程序专有的坑了,但之前写的东西没碰到这次写小程序遇到了就顺便记录一下

问题描述:我要做一个获取用户的openid的环节,于是在js里面有了这块代码

....
onLoad: function (options) {
    //获取openId
      wx.login({
        success: function (res) {
          console.log(res.code)
          //发送请求
          wx.request({
            url: 'https://api.weixin.qq.com/sns/jscode2session?appid=APPIDsecret='+appsecret+'&js_code='+res.code+'&grant_type=authorization_code', //接口地址
            data: {},
            header: {
              'content-type': 'application/json' //默认值
            },
            success: function (info) {
              console.log(info.data)
              console.log("修改之前")
          this.setData({
            openid: info.data.openid
          });
              console.log("修改之后")
            }
          })
        }
      })
  },
.......

在success那里出了问题,我的setData死活没修改我data里面的openid项,控制台也只报修改之前,没有修改之后,尝试各种方法最后得知是this绑定的概念没搞清楚,听别的说this是js里面最容易混淆的几种概念之一,因此借此机会认真学习一下,这里转载一个别人写的博客,关于this绑定机制。

https://www.cnblogs.com/xiaohuochai/p/5735901.html

 

而我这个问题最终的解决方案很简单,就是咋wx.login代码块之外提前定义变量that来存贮外部绑定的this

onLoad: function (options) {
    //获取openID
    var that = this;
      wx.login({
        success: function (res) {
          console.log(res.code)
          //发送请求
          wx.request({
            url: 'https://api.weixin.qq.com/sns/jscode2session?appid=APPID&secret='+appsecret+'&js_code='+res.code+'&grant_type=authorization_code', //接口地址
            data: {},
            header: {
              'content-type': 'application/json' //默认值
            },
            success: function (info) {
              console.log(info.data)
              console.log("修改之前")
              that.setData({
              id: "info.data.openid"
            });
              console.log("修改之后")
            }
          })
        }
      })
 
  },    

 

转载于:https://www.cnblogs.com/zxh2459917510/p/10513029.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值