success: function(res) {} 和 success: res => {}

微信小程序在获取userinfo的过程中采用this碰到一些问题

我login的success回调函数为

success: function(res) {
              if(res.statusCode == 200) {
                console.log(res.data)
                this.globalData.sessionId = res.data.sessionId
              }

此处的this会报错如下

Cannot read property 'globalData' of null;

然后我查看了app.js另外一处的success回调函数

success: res => {
              // 可以将 res 发送给后台解码出 unionId
              this.globalData.userInfo = res.userInfo

              // 由于 getUserInfo 是网络请求,可能会在 Page.onLoad 之后才返回
              // 所以此处加入 callback 以防止这种情况
              if (this.userInfoReadyCallback) {
                this.userInfoReadyCallback(res)
              }

而此处的this有效,我怀疑是success: function(res) {} 和 success: res => {}的区别,于是我修改了第一处的代码为

success: res => {
              if(res.statusCode == 200) {
                console.log(res.data)
                this.globalData.sessionId = res.data.sessionId
              }

然后代码跑通了

如果不想修改回调函数,可以在app.js中增加var that = this,然后此处修改this为that即可。

目前没有深刻的研究小程序的工作原理,也没有详细了解相关html和js的知识,目前只发现这两种用法在this使用情况上的区别,另外有没有其他的区别尚不得而知,希望有了解相关知识的人评论指正。

发布了26 篇原创文章 · 获赞 26 · 访问量 7万+

猜你喜欢

转载自blog.csdn.net/IOT_player/article/details/87031698