微信小程序用戶授權(quán)彈窗 拒絕時(shí)引導(dǎo)用戶重新授權(quán)實(shí)現(xiàn)
前言
我們?cè)陂_發(fā)小程序時(shí),如果想獲取用戶信息,就需要獲取用的授權(quán),如果用戶誤點(diǎn)了拒絕授權(quán),我們?cè)趺礃尤フ_的引導(dǎo)用戶重新授權(quán)呢。今天就來給大家講講如果正確的引導(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)擊了取消,就再也沒有辦法通過點(diǎn)擊授權(quán)按鈕獲取用戶信息了。

所以接下來我們要做的就是在用戶拒絕了授權(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 :用來獲取用戶授權(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è)置頁(yè)其實(shí)很簡(jiǎn)單,只有上圖這么一段代碼。
五,去系統(tǒng)設(shè)置頁(yè)
我們上面第四步的button按鈕,點(diǎn)擊以后,就會(huì)去系統(tǒng)設(shè)置頁(yè)。

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

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

到這里我們就成功的實(shí)現(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("請(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',
})
}
}
})
},
})
有任何關(guān)于小程序的問題可以加我微信:2501902696(備注小程序)
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
怎樣使你的 JavaScript 代碼簡(jiǎn)單易讀(推薦)
這篇文章主要介紹了怎樣使你的 JavaScript 代碼簡(jiǎn)單易讀,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04
JavaScript實(shí)現(xiàn)10秒后再次獲取驗(yàn)證碼
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)10秒后再次獲取驗(yàn)證碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-12-12
在JavaScript中創(chuàng)建對(duì)象的可行方法小結(jié)
在Web前端開發(fā)中,JavaScript是一門功能強(qiáng)大的語(yǔ)言,其核心之一便是對(duì)象的創(chuàng)建與操作,對(duì)象是JavaScript中數(shù)據(jù)結(jié)構(gòu)的重要組成部分,本文將深入探討JavaScript中創(chuàng)建對(duì)象的各種方法,并結(jié)合代碼示例和實(shí)際開發(fā)經(jīng)驗(yàn)進(jìn)行詳細(xì)講解,需要的朋友可以參考下2025-03-03
微信小程序?qū)崿F(xiàn)分享商品海報(bào)功能
這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)分享商品海報(bào)功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-09-09
ie7+背景透明文字不透明超級(jí)簡(jiǎn)單的實(shí)現(xiàn)方法
這篇文章主要介紹了ie7+背景透明文字不透明超級(jí)簡(jiǎn)單的實(shí)現(xiàn)方法,有需要的朋友可以參考一下2014-01-01
JS實(shí)現(xiàn)仿百度輸入框自動(dòng)匹配功能的示例代碼
本篇文章主要是對(duì)JS實(shí)現(xiàn)仿百度輸入框自動(dòng)匹配功能的示例代碼進(jìn)行了介紹,需要的朋友可以過來參考下,希望對(duì)大家有所幫助2014-02-02
JS使用Date對(duì)象實(shí)時(shí)顯示當(dāng)前系統(tǒng)時(shí)間簡(jiǎn)單示例
這篇文章主要介紹了JS使用Date對(duì)象實(shí)時(shí)顯示當(dāng)前系統(tǒng)時(shí)間,涉及javascript基于定時(shí)器動(dòng)態(tài)操作Date對(duì)象相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2018-08-08
JS是否可以跨文件同時(shí)控制多個(gè)iframe頁(yè)面的應(yīng)用技巧
這篇文章給大家詳細(xì)介紹了JS是否可以跨文件同時(shí)控制多個(gè)iframe頁(yè)面的應(yīng)用技巧,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2007-12-12

