十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
小编给大家分享一下微信小程序中wx.getUserInfo如何引导用户授权,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!
公司主营业务:成都网站设计、网站建设、移动网站开发等业务。帮助企业客户真正实现互联网宣传,提高企业的竞争能力。创新互联是一支青春激扬、勤奋敬业、活力青春激扬、勤奋敬业、活力澎湃、和谐高效的团队。公司秉承以“开放、自由、严谨、自律”为核心的企业文化,感谢他们对我们的高要求,感谢他们从不同领域给我们带来的挑战,让我们激情的团队有机会用头脑与智慧不断的给客户带来惊喜。创新互联推出安国免费做网站回馈大家。
具体如下:
首先,在page外定义一个函数用户判断是否为空对象
var isEmptyObject = function (e) { var temp; for (temp in e) return !1; return !0 }
然后,在page中的onload里面调用授权
onLoad: function () { var that = this; if (app.globalData.userInfo) { this.setData({ userInfo: app.globalData.userInfo }) } else if (this.data.canIUse) { // 由于 getUserInfo 是网络请求,可能会在 Page.onLoad 之后才返回 // 所以此处加入 callback 以防止这种情况 app.userInfoReadyCallback = res => { this.setData({ userInfo: res.userInfo }) } } else { // 在没有 open-type=getUserInfo 版本的兼容处理 wx.getUserInfo({ success: res => { app.globalData.userInfo = res.userInfo this.setData({ userInfo: res.userInfo }) that.checkSettingStatu(); }, fail: function () { wx.showModal({ title: '用户未授权', content: '如需正常使用该小程序功能,请按确定并在授权管理中选中“用户信息”,然后点按确定。最后再重新进入小程序即可正常使用。', showCancel: false, success: function (resbtn) { if (resbtn.confirm) { wx.openSetting({ success: function success(resopen) { // 获取用户数据 that.checkSettingStatu(); } }); } } }) } }) } }
最后,在page中定义一个 用于检测 当前授权的状态
checkSettingStatu: function (cb) { var that = this; // 判断是否是第一次授权,非第一次授权且授权失败则进行提醒 wx.getSetting({ success: function success(res) { var authSetting = res.authSetting; if (isEmptyObject(authSetting)) { //第一次 } else { // 没有授权的提醒 if (authSetting['scope.userInfo'] === false) { wx.showModal({ title: '用户未授权', content: '如需正常使用该小程序功能,请按确定并在授权管理中选中“用户信息”,然后点按确定。最后再重新进入小程序即可正常使用。', showCancel: false, success: function (res) { if (res.confirm) { wx.openSetting({ success: function success(res) { console.log() } }); } } }) } else if (authSetting['scope.userInfo'] === true) { //该处用户获取用户的一些授权信息 if (that.data.userInfo) { var nickname = that.data.userInfo.nickName; var gender = that.data.userInfo.gender //性别 0:未知、1:男、2:女 if (gender == 1) { gender = "True" } else if (gender == 2) { gender = "False" } else { gender = "True" } } } } } }) }
看完了这篇文章,相信你对“微信小程序中wx.getUserInfo如何引导用户授权”有了一定的了解,如果想了解更多相关知识,欢迎关注创新互联行业资讯频道,感谢各位的阅读!