舟山闪爸电子技术有限公司

小程序前置授權(quán)組件開發(fā)

在授權(quán)基本信息或者手機號碼時就需要小程序前置授權(quán)組件,那么需要如何開發(fā)呢。

小程序前置授權(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ù)制代碼
 

邏輯

  • 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ù)制代碼

詳細代碼:

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ù)制代碼

其他

  • 可以根據(jù)業(yè)務(wù)需要擴充 open-type 的相關(guān)邏輯,案例中只有 userInfo 和phoneNumber。
  • 不能在slot上直接綁定tap事件,在基礎(chǔ)庫版本為1.9.7及以下版本無法響應(yīng)事件,所以在外部再包一層view


小程序工具開發(fā)公司長沙,是一家有著十年技術(shù)前沿的公司,我們以先進技術(shù)提供并解決各行業(yè)小程序開發(fā),操作簡單,支持多種社群營銷活動,提供一套綜合性的營銷系統(tǒng)。以及可視化模板操作,大大減少人力物力成本。

小程序工具提供多類型商城/門店小程序制作,可視化編輯 1秒生成5步上線。通過拖拽、拼接模塊布局小程序商城頁面,所看即所得,只需要美工就能做出精美商城。更多小程序商店請查看:小程序商店


【本站聲明】
  1、本站文章中所選用的圖片及文字來源于網(wǎng)絡(luò)以及用戶投稿,由于未聯(lián)系到知識產(chǎn)權(quán)人或未發(fā)現(xiàn)有關(guān)知識產(chǎn)權(quán)的登記,如有知識產(chǎn)權(quán)人并不愿意我們使用,如果有侵權(quán)請立即聯(lián)系。
  2、本網(wǎng)站不對文章中所涉及的內(nèi)容真實性、準確性、可靠性負責,僅系客觀性描述,如您需要了解該類商品/服務(wù)詳細的資訊,請您直接與該類商品/服務(wù)的提供者聯(lián)系。


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è)變得更智慧!



▼點擊進入科汛官網(wǎng)了解更多



熱門標簽
SaaS
上/下篇
  • 旅游小程序系統(tǒng)開發(fā)需求

  • 點餐小程序系統(tǒng)功能開發(fā)需求

換一換相關(guān)推薦
精選內(nèi)容
熱點精選