注冊(cè)

微信小程序兼容方式,接口參數(shù)組件兼容性

2017-12-25
導(dǎo)讀:小程序的功能不斷的增加,但是舊版本的微信客戶端并不支持新功能,所以在使用這些新能力的時(shí)候需要做兼容。 文檔會(huì)在組件,API等頁(yè)面描述中帶上各個(gè)功能所支持的版本號(hào)。 可以...

小程序的功能不斷的增加,但是舊版本的微信客戶端并不支持新功能,所以在使用這些新能力的時(shí)候需要做兼容。

文檔會(huì)在組件,API等頁(yè)面描述中帶上各個(gè)功能所支持的版本號(hào)。

可以通過(guò)wx.getSystemInfo或者wx.getSystemInfoSync獲取到小程序的基礎(chǔ)庫(kù)版本號(hào)。

也可以通過(guò)wx.canIUse 詳情 來(lái)判斷是否可以在該基礎(chǔ)庫(kù)版本下直接使用對(duì)應(yīng)的API或者組件

兼容方式 - 接口

對(duì)于新增的 API,可以用以下代碼來(lái)判斷是否支持用戶的手機(jī)。

if (wx.openBluetoothAdapter) {
  wx.openBluetoothAdapter()
} else {
  // 如果希望用戶在最新版本的客戶端上體驗(yàn)?zāi)男〕绦?,可以這樣子提示
  wx.showModal({
    title: '提示',
    content: '當(dāng)前微信版本過(guò)低,無(wú)法使用該功能,請(qǐng)升級(jí)到最新微信版本后重試。'
  })
}

兼容方式 - 參數(shù)

對(duì)于 API 的參數(shù)或者返回值有新增的參數(shù),可以判斷用以下代碼判斷。

wx.showModal({
  success: function(res) {
    if (wx.canIUse('showModal.cancel')) {
      console.log(res.cancel)
    }
  }
})

兼容方式 - 組件

對(duì)于組件,新增的屬性在舊版本上不會(huì)被處理,不過(guò)也不會(huì)報(bào)錯(cuò)。如果特殊場(chǎng)景需要對(duì)舊版本做一些降級(jí)處理,可以這樣子做。

Page({
  data: {
    canIUse: wx.canIUse('button.open-type.contact')
  }
})
<button wx:if="{{canIUse}}" open-type="contact"> 客服消息 </button>
<contact-button wx:else></contact-button>
更多微信小程序開(kāi)發(fā)教程,可以關(guān)注hi小程序。
重磅推薦:小程序開(kāi)店目錄

第一部分:小商店是什么

第二部分:如何開(kāi)通一個(gè)小商店

第三部分:如何登錄小商店

第四部分:開(kāi)店任務(wù)常見(jiàn)問(wèn)題

第五部分:小商店可以賣什么

第六部分:HiShop小程序特色功能

第七部分:小程序直播

第八部分:小程序收貨/物流

第九部分:小程序怎么結(jié)算

第十部分:小程序客服

第十一部分:電商創(chuàng)業(yè)

第十二部分:小程序游戲開(kāi)發(fā)