欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2019年07月29日 16:48:17   作者:編程小石頭  
我們?cè)陂_(kāi)發(fā)小程序時(shí),如果想獲取用戶信息,就需要獲取用的授權(quán),如果用戶誤點(diǎn)了拒絕授權(quán),我們?cè)趺礃尤フ_的引導(dǎo)用戶重新授權(quán)呢。今天就來(lái)給大家講講如果正確的引導(dǎo)用戶授權(quán),需要的朋友可以參考下

前言

我們?cè)陂_(kāi)發(fā)小程序時(shí),如果想獲取用戶信息,就需要獲取用的授權(quán),如果用戶誤點(diǎn)了拒絕授權(quán),我們?cè)趺礃尤フ_的引導(dǎo)用戶重新授權(quán)呢。今天就來(lái)給大家講講如果正確的引導(dǎo)用戶授權(quán)。

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

從上圖可以看出,我們?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í)候需要用戶授權(quán)

我們點(diǎn)擊獲取用戶信息時(shí),通常會(huì)彈出如下提示框,如果用戶點(diǎn)擊了取消,就再也沒(méi)有辦法通過(guò)點(diǎn)擊授權(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)成功,如果用戶沒(méi)有授權(quán),就代表授權(quán)失敗。

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

三,showSettingToast方法如下

 // 打開(kāi)權(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è)置頁(yè)其實(shí)很簡(jiǎn)單,只有上圖這么一段代碼。

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

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

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

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

到這里我們就成功的實(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)")
    }
   }
  })
 },

 // 打開(kāi)權(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',
     })
    }
   }
  })
 },
})

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

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

相關(guān)文章

  • js中使用DOM復(fù)制(克?。┲付ü?jié)點(diǎn)名數(shù)據(jù)到新的XML文件中的代碼

    js中使用DOM復(fù)制(克?。┲付ü?jié)點(diǎn)名數(shù)據(jù)到新的XML文件中的代碼

    使用DOM復(fù)制(克?。┲付ü?jié)點(diǎn)名數(shù)據(jù)到新的XML文件中 ,用到三個(gè)類的相關(guān)知識(shí)點(diǎn) : DOMDocument - DOMNodeList - DOMNode
    2011-07-07
  • javascript格式化json顯示實(shí)例分析

    javascript格式化json顯示實(shí)例分析

    這篇文章主要介紹了javascript格式化json顯示,實(shí)例分析了javascript操作json格式化的相關(guān)技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2015-04-04
  • JS實(shí)現(xiàn)六位字符密碼輸入器功能

    JS實(shí)現(xiàn)六位字符密碼輸入器功能

    這篇文章主要介紹了JS實(shí)現(xiàn)六位字符密碼輸入器功能,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2016-08-08
  • 一文搞懂TypeScript的安裝、使用、自動(dòng)編譯的教程

    一文搞懂TypeScript的安裝、使用、自動(dòng)編譯的教程

    TypeScript 是一種由微軟開(kāi)發(fā)的開(kāi)源、跨平臺(tái)的編程語(yǔ)言。它是 JavaScript 的超集,最終會(huì)被編譯為 JavaScript 代碼,關(guān)于TypeScript的安裝、使用、自動(dòng)編譯很多朋友不是很清楚,今天抽空給大家普及下,感興趣的朋友一起看看吧
    2021-06-06
  • JavaScript定時(shí)器原理詳解

    JavaScript定時(shí)器原理詳解

    這篇文章主要介紹了JavaScript定時(shí)器原理,setTimeout()方法用于設(shè)置一個(gè)定時(shí)器,該定時(shí)器在定時(shí)器到期后執(zhí)行調(diào)用函數(shù),文章圍繞JavaScript定時(shí)器相關(guān)資料展開(kāi)以下內(nèi)容,需要的朋友可以參考一下
    2021-12-12
  • 微信小程序?qū)崿F(xiàn)手寫(xiě)簽名的示例代碼

    微信小程序?qū)崿F(xiàn)手寫(xiě)簽名的示例代碼

    這篇文章主要和大家分享一個(gè)微信小程序的示例代碼,可以實(shí)現(xiàn)手寫(xiě)簽名的效果。文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下
    2022-02-02
  • 微信小程序?qū)崿F(xiàn)藍(lán)牙設(shè)備搜索及連接功能示例詳解

    微信小程序?qū)崿F(xiàn)藍(lán)牙設(shè)備搜索及連接功能示例詳解

    這篇文章主要介紹了微信小程序?qū)崿F(xiàn)藍(lán)牙設(shè)備搜索及連接功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-06-06
  • Node.js中AES加密和其它語(yǔ)言不一致問(wèn)題解決辦法

    Node.js中AES加密和其它語(yǔ)言不一致問(wèn)題解決辦法

    這篇文章主要介紹了Node.js中AES加密和其它語(yǔ)言不一致問(wèn)題解決辦法,例如和C#、JAVA語(yǔ)言相互通信時(shí),需要的朋友可以參考下
    2014-03-03
  • 在微信小程序中使用vant的方法

    在微信小程序中使用vant的方法

    這篇文章主要介紹了在微信小程序中使用vant的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用小程序具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-06-06
  • Bootstrap基本樣式學(xué)習(xí)筆記之表格(2)

    Bootstrap基本樣式學(xué)習(xí)筆記之表格(2)

    Bootstrap提供了一個(gè)清晰的創(chuàng)建表格的布局,這篇文章主要介紹了Bootstrap學(xué)習(xí)筆記之表格基本樣式的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-12-12

最新評(píng)論