微信小程序用户授权接口的使用

2018年改版之前的小程序是可以在用户首次进入小程序时通过wx.getUserInfo直接弹出一个框询问用户是否同意授权信息,或者点击某个控件触发wx.authorize(scope.userInfo)也可以弹出用户信息授权框,改版之后需要通过对button绑定点击事件对授权进行触发:

1 原来的方式

点击控件触发wx.authorize授权

tap: function () {
    wx.authorize({
      scope: 'scope.userInfo',
      success: function () {
        wx.getSetting({
          success: res => {
            console.log(res)
          }
        })  
      },
      fail(res) {console.log(res)
        wx.getSetting({
          success: res => {
            console.log(res)
          }
        })
      }
    })
  }

在这里插入图片描述
wx.authorize(scope.userInfo)不能弹出,未授权的情况下wx.getUserInfo同样不会弹出

但是

对于scope中的其他值仍然可以弹出授权框,比如将上面代码中的scope改成scope.invoice
在这里插入图片描述

2 改版以后

需要通过button组件进行触发,并设置open-type=“getUserInfo”,以下是官方demo中的代码

<view class="userinfo">
   <button wx:if="{{!hasUserInfo && canIUse}}" open-type="getUserInfo" bindgetuserinfo="getUserInfo"> 获取头像昵称 </button>
   <block wx:else>
     <image bindtap="bindViewTap" class="userinfo-avatar" src="{{userInfo.avatarUrl}}" mode="cover"></image>
     <text class="userinfo-nickname">{{userInfo.nickName}}</text>
   </block>
 </view>

getUserInfo: function(e) {
   console.log(e)
   app.globalData.userInfo = e.detail.userInfo
   this.setData({
     userInfo: e.detail.userInfo,
     hasUserInfo: true
   })
 }

点击button以后弹出授权框,如果允许授权,可以从bindgetuserinfo事件中获取到用户信息
在这里插入图片描述
点击获取头像昵称后弹出
在这里插入图片描述

3 不需要授权即可使用用户信息的方式

使用open-data 可以直接展示用户的头像 昵称信息 不需要授权,这种情况用于仅需要展示头像的页面,而不是用户登录

<open-data type="groupName" open-gid="xxxxxx"></open-data>
<open-data type="userAvatarUrl" bindtap="tap"></open-data>
<open-data type="userGender" lang="zh_CN"></open-data>

在这里插入图片描述

  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值