微信小程序如何通過用戶授權(quán)獲取手機號(getPhoneNumber)
這篇文章主要介紹了微信小程序如何通過用戶授權(quán)獲取手機號(getPhoneNumber),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
小程序有一個獲取用戶很便捷的api,就是通過getPhoneNumber獲取用戶的已經(jīng)綁定微信的手機號碼。有一點要大家注意,現(xiàn)在微信和注重用戶體驗,有些方法都是需要用戶主動去觸發(fā)才能調(diào)用的,比如getPhoneNumber。
官方文檔:https://developers.weixin.qq.com/miniprogram/dev/framework/open-ability/getPhoneNumber.html
實現(xiàn)思路:

直接上干貨:
1、
<button open-type="getPhoneNumber" bindgetphonenumber="getPhoneNumber"></button>
2、JS內(nèi)getPhoneNumbe組件函數(shù)(該事件中最重要的就是在wx.login登錄后發(fā)起接口請求),這里需要配置參數(shù)來給接口:
這些是必不可少的參數(shù),這些齊備才能算一個合法的請求。
appid: “你的小程序APPID”, secret: “你的小程序appsecret”, code: res.code, encryptedData: telObj, iv: ivObj
//通過綁定手機號登錄
getPhoneNumber: function (e) {
var ivObj = e.detail.iv
var telObj = e.detail.encryptedData
var codeObj = "";
var that = this;
//------執(zhí)行Login---------
wx.login({
success: res => {
console.log('code轉(zhuǎn)換', res.code);
//用code傳給服務(wù)器調(diào)換session_key
wx.request({
url: 'https://你的接口文件路徑', //接口地址
data: {
appid: "你的小程序APPID",
secret: "你的小程序appsecret",
code: res.code,
encryptedData: telObj,
iv: ivObj
},
success: function (res) {
phoneObj = res.data.phoneNumber;
console.log("手機號=", phoneObj)
wx.setStorage({ //存儲數(shù)據(jù)并準(zhǔn)備發(fā)送給下一頁使用
key: "phoneObj",
data: res.data.phoneNumber,
})
}
})
//-----------------是否授權(quán),授權(quán)通過進入主頁面,授權(quán)拒絕則停留在登陸界面
if (e.detail.errMsg == 'getPhoneNumber:user deny') { //用戶點擊拒絕
wx.navigateTo({
url: '../index/index',
})
} else { //允許授權(quán)執(zhí)行跳轉(zhuǎn)
wx.navigateTo({
url: '../test/test',
})
}
}
});
},
最終結(jié)果展示:

點擊"拒絕",開發(fā)者能捕捉到該事件 ,此時getPhoneNumber 函數(shù)返回 e.detail.errMsg 為 getPhoneNumber:user deny
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
javascript canvas實現(xiàn)簡易時鐘例子
這篇文章主要為大家詳細(xì)介紹了javascript canvas實現(xiàn)簡易時鐘例子,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-09-09
javascript中Array數(shù)組的迭代方法實例分析
這篇文章主要介紹了javascript中Array數(shù)組的迭代方法,實例分析了Array數(shù)組的迭代方法定義與使用技巧,需要的朋友可以參考下2015-02-02
JavaScript之class繼承_動力節(jié)點Java學(xué)院整理
這篇文章主要介紹了JavaScript之class繼承,新的關(guān)鍵字class從ES6開始正式被引入到JavaScript中。class的目的就是讓定義類更簡單,有興趣的可以了解一下2017-07-07
談?wù)別ncodeURI和encodeURIComponent以及escape的區(qū)別與應(yīng)用
encodeURI和encodeURIComponent以及escape,這三個都是用來編碼的,本篇文章給大家介紹encodeURI和encodeURIComponent以及escape的區(qū)別與應(yīng)用,感興趣的朋友一起學(xué)習(xí)吧2015-11-11
webpack實現(xiàn)一個行內(nèi)樣式px轉(zhuǎn)vw的loader示例
這篇文章主要介紹了webpack實現(xiàn)一個行內(nèi)樣式px轉(zhuǎn)vw的loader示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-09-09

