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使用情况上的区别,另外有没有其他的区别尚不得而知,希望有了解相关知识的人评论指正。


————————————————————————分割线————————————————————————


箭头函数中this指向window(Page)

而采用如下方式时:

xxx:function(){}

执行xxx就执行了一个匿名函数,其中的this指向包含xxx这个键的对象(js中什么东西都能是对象)。

评论中有人问是不是建议用success: res => {},并不是这个意思。用哪个方式取决于项目,要考虑之前说的this指向问题:你想要this指向哪个对象?如果你想用的就在包含xxx的这个map中,就没必要用箭头函数,而且老浏览器不支持ES6语法。如果你需要的在window(page)对象下,就可以用箭头函数。

或者在外部用另外一个变量储存指向window(page)的this

或者在匿名函数中采用闭包,也可以解决这个问题,不过函数中再写个函数来实现闭包的情形很少

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • A类问题(技术) 1. 请谈谈微信小程序作用? project.config.json 项目配置文件,用得最多的就...
    七月鎏金阅读 1,661评论 0 3
  • 搭建项目 创建新项目(需要一个appId) 导入已有项目 小程序配置 小程序知识体系目录 不同框架都会涉及到的九个...
    北冥有鱼_425c阅读 304评论 0 3
  • 写在前面 微信小程序出来也蛮久了,经过了市场的考验,已经站稳脚跟,融入到了各行各业,市场需求激增打来的是开发人员的...
    月梦佳期阅读 1,712评论 1 1
  • 腾讯视频是一个让我们都喜爱的视频观看平台,用户群体也相当庞大。小编也非常喜欢使用腾讯视频播放软件,在娱乐的时间之...
    袁德红orJayson阅读 865评论 0 1
  • 久违的晴天,家长会。 家长大会开好到教室时,离放学已经没多少时间了。班主任说已经安排了三个家长分享经验。 放学铃声...
    飘雪儿5阅读 7,567评论 16 22