微信小程序如何通過用戶授權(quán)獲取手機號(getPhoneNumber)
這篇文章主要介紹了微信小程序如何通過用戶授權(quán)獲取手機號(getPhoneNumber),文中通過示例代碼介紹的非常詳細,對大家的學(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ù)并準備發(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)簡易時鐘例子
這篇文章主要為大家詳細介紹了javascript canvas實現(xiàn)簡易時鐘例子,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-09-09javascript中Array數(shù)組的迭代方法實例分析
這篇文章主要介紹了javascript中Array數(shù)組的迭代方法,實例分析了Array數(shù)組的迭代方法定義與使用技巧,需要的朋友可以參考下2015-02-02JavaScript之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-11webpack實現(xiàn)一個行內(nèi)樣式px轉(zhuǎn)vw的loader示例
這篇文章主要介紹了webpack實現(xiàn)一個行內(nèi)樣式px轉(zhuǎn)vw的loader示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-09-09