在授權(quán)基本信息或者手機號碼時就需要小程序前置授權(quán)組件,那么需要如何開發(fā)呢。
因業(yè)務(wù)上的需求,需要在某些點擊區(qū)域上增加這樣一層邏輯:如果該用戶沒有授權(quán)基本信息 / 手機號,在點擊該區(qū)域時,先彈出微信的授權(quán)彈窗,授權(quán)成功后再進行下一步的業(yè)務(wù)操作。
因為授權(quán)基本信息 / 手機號 必須使用小程序原生的的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ù)制代碼
需要在組件外部綁定點擊區(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ù)制代碼
詳細代碼:
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') { /* * 獲取到用戶手機號后的業(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ù)制代碼
小程序工具開發(fā)公司長沙,是一家有著十年技術(shù)前沿的公司,我們以先進技術(shù)提供并解決各行業(yè)小程序開發(fā),操作簡單,支持多種社群營銷活動,提供一套綜合性的營銷系統(tǒng)。以及可視化模板操作,大大減少人力物力成本。
小程序工具提供多類型商城/門店小程序制作,可視化編輯 1秒生成5步上線。通過拖拽、拼接模塊布局小程序商城頁面,所看即所得,只需要美工就能做出精美商城。更多小程序商店請查看:小程序商店
KESION 科汛軟件
KESION 科汛軟件是國內(nèi)領(lǐng)先的在線教育軟件及私域社交電商軟件服務(wù)提供商,長期專注于為企業(yè)提供在線教育軟件及社交電商SaaS平臺解決方案。
公司核心產(chǎn)品云開店SaaS社交電商服務(wù)平臺、在線教育SaaS服務(wù)平臺、教育企業(yè)數(shù)字化SaaS云平臺、企微營銷助手、私有化獨立部署品牌網(wǎng)校和在線教育咨詢等。KESION 不斷通過技術(shù)創(chuàng)新,提供產(chǎn)品和服務(wù),助力企業(yè)向數(shù)字化轉(zhuǎn)型,通過科技驅(qū)動商業(yè)革新,讓商業(yè)變得更智慧!
對于旅游行業(yè)來說,開發(fā)一款小程序比起app更節(jié)約成本,而且還可以借助微信這一大的社交流量給線下來引流,開發(fā)旅游小程序系統(tǒng)非常適合需求。...
對于餐飲行業(yè),開發(fā)一個點餐小程序非常適合餐飲行業(yè)的需求,因為點餐剛好與微信小程序“隨用隨走”原理相吻合,一般大家到門店點餐或者點外賣會選擇最便捷的方式來進行,這里...