您好,登錄后才能下訂單哦!
今天小編給大家分享一下小程序前置授權(quán)組件如何開發(fā)的相關(guān)知識點,內(nèi)容詳細(xì),邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。
因為授權(quán)基本信息 / 手機(jī)號 必須使用小程序原生的的button,然后指定 open-type 后通過回調(diào)才能拿到相關(guān)信息( wx.getUserInfo() 已經(jīng)不能彈窗啦,必須通過button彈窗),但是需要前置授權(quán)的點擊區(qū)域樣式又不一定是button的樣式,所以決定使用一個透明的原生button 覆蓋在點擊區(qū)域之上,在視覺上實現(xiàn)無差別授權(quán)。通過是否授權(quán)字段來決定該按鈕是否顯示。
因為小程序中可能有多個需要相同授權(quán)的點擊區(qū)域,所以決定用觀察者模式來實現(xiàn),即其中一個組件授權(quán)后,更新所有相同授權(quán)的組件,隱藏授權(quán)button。
因為需要讓授權(quán)button完全覆蓋在點擊區(qū)域之上,所以需要讓slot里面的內(nèi)容撐開父級定位元素,然后授權(quán)button絕對定位在該父元素內(nèi),寬高都設(shè)為100%即可。也可以通過小程序組件的 externalClasses 從組件外部指定樣式。代碼如下:
.wrapper { position: relative; width: 100%; height: 100%; .auth { position: absolute; width: 100%; height: 100%; opacity: 0; top: 0; left: 0; z-index: 10; } } 復(fù)制代碼
<view class="wrapper m-class"><view bind:tap="handleTap"> <slot></slot></view><block wx:if="{{!authorized}}"> <button class="auth" open-type="{{openType}}" bindgetphonenumber="getPhoneNumber" bindgetuserinfo="getUserInfo"> </button></block> </view> 復(fù)制代碼
properties
openType 通過設(shè)置不同的參數(shù)來設(shè)置組件的授權(quán)類型
data
authorized 通過該值控制 授權(quán)按鈕是否顯示
attached
在組件的 attached 階段,判斷用戶是否授權(quán),如果授權(quán),直接將 authorized 置為 false
如果用戶沒有授權(quán),則初始化監(jiān)聽器
detached
移除監(jiān)聽器
需要在組件外部綁定點擊區(qū)域本身的點擊事件,在已經(jīng)授權(quán)的情況下會觸發(fā)點擊回調(diào)。
<authorization-block bind:action="callBack" m-class="xxx"><view class="u-m"> xxxxxxx </view> </authorization-block> 復(fù)制代碼
詳細(xì)代碼:
import event from '../../utils/event' Component({ externalClasses: ['m-class'], properties: { openType: { type: String, value: 'getUserInfo' } }, data: { authorized: false }, methods: { getPhoneNumber ({detail}) { const vm = this if (detail.errMsg === 'getPhoneNumber:ok') { /* * 獲取到用戶手機(jī)號后的業(yè)務(wù)代碼 * */ vm._triggerEvent(detail) } }, getUserInfo ({detail: {userInfo: {avatarUrl, nickName}, errMsg}}) { const vm = this if (errMsg === 'getUserInfo:ok') { /* * 獲取到用戶信息后的業(yè)務(wù)代碼 * */ vm._triggerEvent() } }, _triggerEvent (arg) { const vm = this /* * 觸發(fā)監(jiān)聽器后,再觸發(fā)點擊區(qū)域本身的點擊回調(diào) * */ event.triggerEvent([vm.data.config.eventName], true) vm.triggerEvent('action', arg) }, handleTap () { const vm = this vm.triggerEvent('action') } }, attached () { const vm = this let config switch (vm.data.openType) { case 'getUserInfo': config = { eventName: 'userInfo' } break case 'getPhoneNumber': config = { eventName: 'phoneNumber' } break } if (getApp().globalData[config.eventName]) { vm.setData({ authorized: true }) } else { event.addEventListener([config.eventName], vm, (authorized) => { if (authorized) { vm.setData({ authorized: true }) } }) } vm.setData({ config }) }, detached () { const vm = this event.removeEventListener([vm.data.config.eventName], vm) } }) 復(fù)制代碼
可以根據(jù)業(yè)務(wù)需要擴(kuò)充 open-type 的相關(guān)邏輯,案例中只有 userInfo 和phoneNumber。
不能在slot上直接綁定tap事件,在基礎(chǔ)庫版本為1.9.7及以下版本無法響應(yīng)事件,所以在外部再包一層view
以上就是“小程序前置授權(quán)組件如何開發(fā)”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學(xué)習(xí)更多的知識,請關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。