博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
获取个人微信信息
阅读量:7302 次
发布时间:2019-06-30

本文共 1254 字,大约阅读时间需要 4 分钟。

上一篇教程中写道,开发工具会生成一个默认的程序框架,其中程序的主流程代码包含在app.js中。默认实现中,该部分功能比较简单,不过对于学研究小程序开发还是比较有价值的。

由于代码行数不多,下面一次性贴出来后进行讲解

//app.jsApp({  onLaunch: function () { //调用API从本地缓存中获取数据 var logs = wx.getStorageSync('logs') || [] logs.unshift(Date.now()) wx.setStorageSync('logs', logs) }, getUserInfo:function(cb){ var that = this if(this.globalData.userInfo){ typeof cb == "function" && cb(this.globalData.userInfo) }else{ //调用登录接口 wx.login({ success: function () { wx.getUserInfo({ success: function (res) { that.globalData.userInfo = res.userInfo typeof cb == "function" && cb(that.globalData.userInfo) } }) } }) } }, globalData:{ userInfo:null } })

代码中定义了一个App对象,该对象包含onLaunchgetUserInfo两个方法和globalData成员变量 其中onLaunch方法会在程序启动时由框架来进行调用。在该方法中,程序通过微信提供的本地存储接口获取了一个logs变量,第一次获取时会返回空,这时将变量初始化为空数组。之后在数组头部添加一个格式化的时间字符串,之后将数组变量存储在本地。

微信小程序框架提供了一系列api来帮助我们进行本地数据存储,上面的代码中使用到了wx.getStorageSyncwx.setStorageSync两个api,更多相关api可以参考

getUserInfo方法很容易理解,会执行获取用户信息的功能。不过该方法不同于onLaunch,它不是框架预设的函数,因此不会自动触发调用。该方法是在index.js的onload方法中调用的(关于index.js部分会在后续教程中讲解)。该方法需要调用者传递一个名为cb的参数,首先判断是否获取过用户信息,如果获取过并且cb是函数的话,就会调用cb函数并将globalData成员变量传递进去,否则将调用wx.login接口来获取用户信息。

对js不熟悉或者很少接触脚本语言的同学可能会对上述代码的语法产生困惑,这几行代码涉及到了函数回调,匿名函数,闭包等概念,我后续会针对这部分单独写一篇教程。

代码最后定义了 globalData成员变量,该成员包含userInfo变量,用来保存用户信息。

转载地址:http://qvhnm.baihongyu.com/

你可能感兴趣的文章
shc程序的原理--以实例分析
查看>>
phantomjs实现免费在线网页截图工具-toolfk程序员在线工具网
查看>>
spring jdbcTemplate多数据源简单实用
查看>>
JMS
查看>>
zookeeper伪分布安装和使用
查看>>
Sublime使用snippet实现快速输入代码块
查看>>
DDPush-任意门推送-概述
查看>>
Exchange 2007收件人管理
查看>>
解决kvm虚拟机直接访问宿主机器上面某个磁盘问题
查看>>
读后感(一直埋头学习的兄弟们)
查看>>
使用Cisco Packet Tracer之DHCP服务于不同的VLAN
查看>>
windows下生成https证书
查看>>
十六进制数组成的字符串 转换成 对应的ASCII字符串
查看>>
Linux上的mysql集群
查看>>
CompletionService小记
查看>>
使用Supervisor管理Redis进程
查看>>
Android开发之模拟器访问本地服务器需注意事项
查看>>
ip source route
查看>>
2015年终总结
查看>>
squid实现反向代理!!!
查看>>