微信小程序获取用户信息的两种方法wx.getUserInfo与open-data实例分析
程序员文章站
2022-06-09 10:36:20
本文实例讲述了微信小程序获取用户信息的两种方法wx.getuserinfo与open-data。分享给大家供大家参考,具体如下:
在此之前,小程序获取微信的头像,昵称之类...
本文实例讲述了微信小程序获取用户信息的两种方法wx.getuserinfo与open-data。分享给大家供大家参考,具体如下:
在此之前,小程序获取微信的头像,昵称之类的用户信息,我用的都是wx.getuserinfo,例如:
onload: function (options) { var that = this; //获取用户信息 wx.getuserinfo({ success: function (res) { console.log(res); that.data.userinfo = res.userinfo; that.setdata({ userinfo: that.data.userinfo }) } }) },
wx.getuserinfo
需要用户授权scope.userinfo
,也就是那个授权弹窗。
但是!!!重点来了,自从微信接口有了新的调整之后 这个wx.getuserinfo()
便不再出现授权弹窗了,需要使用button做引导~
<!--wxml--> <!-- 需要使用 button 来授权登录 --> <button wx:if="{{caniuse}}" open-type="getuserinfo" bindgetuserinfo="bindgetuserinfo">授权登录</button> <view wx:else>请升级微信版本</view>
js:
page({ data: { caniuse: wx.caniuse('button.open-type.getuserinfo') }, onload: function() { // 查看是否授权 wx.getsetting({ success: function(res){ if (res.authsetting['scope.userinfo']) { // 已经授权,可以直接调用 getuserinfo 获取头像昵称 wx.getuserinfo({ success: function(res) { console.log(res.userinfo) } }) } } }) }, bindgetuserinfo: function(e) { console.log(e.detail.userinfo) } })
这就是等于一步变两步了~现在用button的话 可以在产品上多加引导,不会显得那么突兀的出来一个弹窗了
然鹅,如果你仅仅只是想展示用户信息的话,那便使用open-data 吧,如下:
<!-- 如果只是展示用户头像昵称,可以使用 <open-data /> 组件 --> <open-data type="useravatarurl"></open-data> <open-data type="usernickname"></open-data>
只需要这两行wxml的代码,便可展示微信昵称和头像,是不是很惊喜!
希望本文所述对大家微信小程序开发有所帮助。