溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

微信小程序如何實(shí)現(xiàn)用戶授權(quán)彈窗并拒絕時(shí)引導(dǎo)用戶重新授權(quán)

發(fā)布時(shí)間:2021-07-20 09:26:26 來(lái)源:億速云 閱讀:277 作者:小新 欄目:web開發(fā)

小編給大家分享一下微信小程序如何實(shí)現(xiàn)用戶授權(quán)彈窗并拒絕時(shí)引導(dǎo)用戶重新授權(quán),相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

先看效果圖

微信小程序如何實(shí)現(xiàn)用戶授權(quán)彈窗并拒絕時(shí)引導(dǎo)用戶重新授權(quán)

從上圖可以看出,我們?cè)谟脩酎c(diǎn)擊拒絕授權(quán)時(shí),我們會(huì)彈出一個(gè)提示框,提示用戶去設(shè)置頁(yè)重新授權(quán),當(dāng)用戶去授權(quán)頁(yè)重新授權(quán)以后,我們?cè)倩氐绞醉?yè),點(diǎn)擊獲取用戶信息時(shí),就可以成功的獲取到用戶信息了。
如下圖藍(lán)色框里,就是我們成功的獲取的用戶信息。

微信小程序如何實(shí)現(xiàn)用戶授權(quán)彈窗并拒絕時(shí)引導(dǎo)用戶重新授權(quán) 

一,我們獲取用戶信息的時(shí)候需要用戶授權(quán)

我們點(diǎn)擊獲取用戶信息時(shí),通常會(huì)彈出如下提示框,如果用戶點(diǎn)擊了取消,就再也沒有辦法通過點(diǎn)擊授權(quán)按鈕獲取用戶信息了。

微信小程序如何實(shí)現(xiàn)用戶授權(quán)彈窗并拒絕時(shí)引導(dǎo)用戶重新授權(quán)

所以接下來(lái)我們要做的就是在用戶拒絕了授權(quán)時(shí),引導(dǎo)用戶去設(shè)置頁(yè)重新授權(quán)。
把獲取用戶授權(quán)的代碼先貼給大家

<button open-type="getUserInfo" bindgetuserinfo="getUserInfo"> 授權(quán)獲取頭像昵稱 </button>

二,檢測(cè)用戶是否授權(quán)

我們?cè)谟脩酎c(diǎn)擊了上面定義的button按鈕后,做權(quán)限檢測(cè)。代碼如下。

 getUserInfo: function(e) {
  let that = this;
  // console.log(e)
  // 獲取用戶信息
  wx.getSetting({
   success(res) {
    // console.log("res", res)
    if (res.authSetting['scope.userInfo']) {
     console.log("已授權(quán)=====")
     // 已經(jīng)授權(quán),可以直接調(diào)用 getUserInfo 獲取頭像昵稱
     wx.getUserInfo({
      success(res) {
       console.log("獲取用戶信息成功", res)
       that.setData({
        name: res.userInfo.nickName
       })
      },
      fail(res) {
       console.log("獲取用戶信息失敗", res)
      }
     })
    } else {
     console.log("未授權(quán)=====")
     that.showSettingToast("請(qǐng)授權(quán)")
    }
   }
  })
 },

給大家簡(jiǎn)單解析下。

wx.getSetting :用來(lái)獲取用戶授權(quán)列表

if (res.authSetting['scope.userInfo']) 代碼用戶授權(quán)成功,如果用戶沒有授權(quán),就代表授權(quán)失敗。

在授權(quán)失敗時(shí),我們調(diào)用that.showSettingToast()方法

三,showSettingToast方法如下

 // 打開權(quán)限設(shè)置頁(yè)提示框
 showSettingToast: function(e) {
  wx.showModal({
   title: '提示!',
   confirmText: '去設(shè)置',
   showCancel: false,
   content: e,
   success: function(res) {
    if (res.confirm) {
     wx.navigateTo({
      url: '../setting/setting',
     })
    }
   }
  })
 }

這方法做的就是引導(dǎo)用戶去設(shè)置頁(yè)。

四,我們的設(shè)置頁(yè)

微信小程序如何實(shí)現(xiàn)用戶授權(quán)彈窗并拒絕時(shí)引導(dǎo)用戶重新授權(quán)

我們的設(shè)置頁(yè)其實(shí)很簡(jiǎn)單,只有上圖這么一段代碼。

微信小程序如何實(shí)現(xiàn)用戶授權(quán)彈窗并拒絕時(shí)引導(dǎo)用戶重新授權(quán) 

五,去系統(tǒng)設(shè)置頁(yè)

我們上面第四步的button按鈕,點(diǎn)擊以后,就會(huì)去系統(tǒng)設(shè)置頁(yè)。

微信小程序如何實(shí)現(xiàn)用戶授權(quán)彈窗并拒絕時(shí)引導(dǎo)用戶重新授權(quán)

可以看到系統(tǒng)設(shè)置頁(yè),有一個(gè)開關(guān),當(dāng)用戶點(diǎn)擊開關(guān)時(shí),就可以重新授權(quán)啦。

微信小程序如何實(shí)現(xiàn)用戶授權(quán)彈窗并拒絕時(shí)引導(dǎo)用戶重新授權(quán)

重新授權(quán)成功以后,我們回到首頁(yè),就可以成功的獲取到用戶信息了。

微信小程序如何實(shí)現(xiàn)用戶授權(quán)彈窗并拒絕時(shí)引導(dǎo)用戶重新授權(quán)

到這里我們就成功的實(shí)現(xiàn)了引導(dǎo)用戶授權(quán)的功能了。

把index.wxml和index.js代碼貼出來(lái)給大家

index.wxml

<!--index.wxml-->
<button open-type="getUserInfo" bindgetuserinfo="getUserInfo"> 授權(quán)獲取頭像昵稱 </button>
<text>{{name}}</text>

index.js

//index.js
Page({
 getUserInfo: function(e) {
  let that = this;
  // console.log(e)
  // 獲取用戶信息
  wx.getSetting({
   success(res) {
    // console.log("res", res)
    if (res.authSetting['scope.userInfo']) {
     console.log("已授權(quán)=====")
     // 已經(jīng)授權(quán),可以直接調(diào)用 getUserInfo 獲取頭像昵稱
     wx.getUserInfo({
      success(res) {
       console.log("獲取用戶信息成功", res)
       that.setData({
        name: res.userInfo.nickName
       })
      },
      fail(res) {
       console.log("獲取用戶信息失敗", res)
      }
     })
    } else {
     console.log("未授權(quán)=====")
     that.showSettingToast("請(qǐng)授權(quán)")
    }
   }
  })
 },

 // 打開權(quán)限設(shè)置頁(yè)提示框
 showSettingToast: function(e) {
  wx.showModal({
   title: '提示!',
   confirmText: '去設(shè)置',
   showCancel: false,
   content: e,
   success: function(res) {
    if (res.confirm) {
     wx.navigateTo({
      url: '../setting/setting',
     })
    }
   }
  })
 },
})

以上是“微信小程序如何實(shí)現(xiàn)用戶授權(quán)彈窗并拒絕時(shí)引導(dǎo)用戶重新授權(quán)”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI