今天小編給大家分享一下小程序前置授權組件如何開發的相關知識點,內容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。
因為授權基本信息 / 手機號 必須使用小程序原生的的button,然后指定 open-type 后通過回調才能拿到相關信息( wx.getUserInfo() 已經不能彈窗啦,必須通過button彈窗),但是需要前置授權的點擊區域樣式又不一定是button的樣式,所以決定使用一個透明的原生button 覆蓋在點擊區域之上,在視覺上實現無差別授權。通過是否授權字段來決定該按鈕是否顯示。
因為小程序中可能有多個需要相同授權的點擊區域,所以決定用觀察者模式來實現,即其中一個組件授權后,更新所有相同授權的組件,隱藏授權button。
因為需要讓授權button完全覆蓋在點擊區域之上,所以需要讓slot里面的內容撐開父級定位元素,然后授權button絕對定位在該父元素內,寬高都設為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;
}
}
復制代碼<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>
復制代碼properties
openType 通過設置不同的參數來設置組件的授權類型
data
authorized 通過該值控制 授權按鈕是否顯示
attached
在組件的 attached 階段,判斷用戶是否授權,如果授權,直接將 authorized 置為 false
如果用戶沒有授權,則初始化監聽器
detached
移除監聽器
需要在組件外部綁定點擊區域本身的點擊事件,在已經授權的情況下會觸發點擊回調。
<authorization-block bind:action="callBack" m-class="xxx"><view class="u-m"> xxxxxxx </view> </authorization-block> 復制代碼
詳細代碼:
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') {
/*
* 獲取到用戶手機號后的業務代碼
* */
vm._triggerEvent(detail)
}
},
getUserInfo ({detail: {userInfo: {avatarUrl, nickName}, errMsg}}) {
const vm = this
if (errMsg === 'getUserInfo:ok') {
/*
* 獲取到用戶信息后的業務代碼
* */
vm._triggerEvent()
}
},
_triggerEvent (arg) {
const vm = this
/*
* 觸發監聽器后,再觸發點擊區域本身的點擊回調
* */
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)
}
})
復制代碼可以根據業務需要擴充 open-type 的相關邏輯,案例中只有 userInfo 和phoneNumber。
不能在slot上直接綁定tap事件,在基礎庫版本為1.9.7及以下版本無法響應事件,所以在外部再包一層view
以上就是“小程序前置授權組件如何開發”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。