亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時間:2019年07月29日 16:48:17   作者:編程小石頭  
我們在開發(fā)小程序時,如果想獲取用戶信息,就需要獲取用的授權(quán),如果用戶誤點了拒絕授權(quán),我們怎么樣去正確的引導(dǎo)用戶重新授權(quán)呢。今天就來給大家講講如果正確的引導(dǎo)用戶授權(quán),需要的朋友可以參考下

前言

我們在開發(fā)小程序時,如果想獲取用戶信息,就需要獲取用的授權(quán),如果用戶誤點了拒絕授權(quán),我們怎么樣去正確的引導(dǎo)用戶重新授權(quán)呢。今天就來給大家講講如果正確的引導(dǎo)用戶授權(quán)。

老規(guī)矩,先看效果圖

從上圖可以看出,我們在用戶點擊拒絕授權(quán)時,我們會彈出一個提示框,提示用戶去設(shè)置頁重新授權(quán),當用戶去授權(quán)頁重新授權(quán)以后,我們再回到首頁,點擊獲取用戶信息時,就可以成功的獲取到用戶信息了。
如下圖藍色框里,就是我們成功的獲取的用戶信息。

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

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

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

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

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

我們在用戶點擊了上面定義的button按鈕后,做權(quán)限檢測。代碼如下。

 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("請授權(quán)")
    }
   }
  })
 },

給大家簡單解析下。

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

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

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

三,showSettingToast方法如下

 // 打開權(quán)限設(shè)置頁提示框
 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è)置頁。

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

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

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

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

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

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

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

把index.wxml和index.js代碼貼出來給大家

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("請授權(quán)")
    }
   }
  })
 },

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

有任何關(guān)于小程序的問題可以加我微信:2501902696(備注小程序)

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論