小程序的功能不斷的增加赠堵,但是舊版本的微信客戶端并不支持新功能,所以在使用這些新能力的時(shí)候需要做兼容起暮。
文檔會在組件,API等頁面描述中帶上各個(gè)功能所支持的版本號状勤。
可以通過wx.getSystemInfo或者wx.getSystemInfoSync獲取到小程序的基礎(chǔ)庫版本號鞋怀。
兼容方式 - 接口
對于新增的 API双泪,可以用以下代碼來判斷是否支持用戶的手機(jī)持搜。
if(wx.openBluetoothAdapter) {? wx.openBluetoothAdapter()}else{// 如果希望用戶在最新版本的客戶端上體驗(yàn)?zāi)男〕绦蛎芩疲梢赃@樣子提示wx.showModal({? ? title:'提示',? ? content:'當(dāng)前微信版本過低,無法使用該功能葫盼,請升級到最新微信版本后重試残腌。'})}
兼容方式 - 參數(shù)
對于 API 的參數(shù)或者返回值有新增的參數(shù),可以判斷用以下代碼判斷贫导。
constSDKVersion = wx.getSystemInfoSync().SDKVersion ||'1.0.0'const[MAJOR, MINOR, PATCH] = SDKVersion.split('.').map(Number)constcanIUse = apiName => {if(apiName ==='showModal.cancel') {returnMAJOR >=1&& MINOR >=1}returntrue}wx.showModal({? success:function(res){if(canIUse('showModal.cancel')) {console.log(res.cancel)? ? }? }})
兼容方式 - 組件
對于組件抛猫,新增的屬性在舊版本上不會被處理,不過也不會報(bào)錯(cuò)孩灯。如果特殊場景需要對舊版本做一些降級處理闺金,可以這樣子做。
Page({? data: {? ? canIUse: canIUse('button.open-type.contact')? }})
客服消息