关于微信小程序兼容性相关问题浅析

2018/3/31 18:18:50
摘要: 微信小程序官方开发者,在对其功能的不断升级过程中,会有新的组件以及API被发布,但是新的内容一般只会支持新版本、高版本

微信小程序官方开发者,在对其功能的不断升级过程中,会有新的组件以及API被发布,但是新的内容一般只会支持新版本、高版本,低版本在无法使用的情况下,需求对其进行兼容性处理。本文来说说如何对小程序新的组件与API进行兼容性处理,方法如下。

  1、利用wx.getSystemInfo或者wx.getSystemInfoSync获取版本号

通过wx.getSystemInfo或wx.getSystemInfoSync,可以让开发者去获取到小程序的基础库版本号SDKVersion,再获取到基础库版本号之后,将其与某功能所支持的版本进行比较。

例:wx.getSystemInfo({

  success: function(res) {

    console.log(res.SDKVersion)

  }

})

2、判断当前版本的适用性

利用wx.canIUse(String)去判断小程序的API、回调、参数、组件等能否在当前版本使用。

其中String参数的使用方式为,使用${API}.${method}.${param}.${options}或${component}.${attribute}.${option}方式来调用。

${API} 代表 API 名字

${method} 代表调用方式,有效值为return, success, object, callback

${param} 代表参数或者返回值

${options} 代表参数的可选值

${component} 代表组件名字

${attribute} 代表组件属性

${option} 代表组件属性的可选值

例:

wx.canIUse('openBluetoothAdapter')

wx.canIUse('getSystemInfoSync.return.screenWidth')

wx.canIUse('getSystemInfo.success.screenWidth')

wx.canIUse('showToast.object.image')

wx.canIUse('onCompassChange.callback.direction')

wx.canIUse('request.object.method.GET')

wx.canIUse('contact-button')

wx.canIUse('text.selectable')

wx.canIUse('button.open-type.contact')

需要注意的是 wx.canIUse 这个 api 本身也是需要判断是否支持的,可以先通过 if(wx.canIUse) 判断其是否支持,然后再使用 wx.canIUse 判断其他的属性是否支持。

3、判断是否兼容

对新增的新增的API进行兼容性判断,比直接通过if(api)的方式判断该能否调用。

例1:

if (wx.openBluetoothAdapter) {

    wx.openBluetoothAdapter()

} else {

    // 如果希望用户在最新版本的客户端上体验您的小程序,可以这样子提示

    wx.showModal({

        title: '提示',

        content: '当前微信版本过低,无法使用该功能,请升级到最新微信版本后重试。'

    })

}

例2:

加载过程中的进度框,可以避免用户在加载过程中进行操作导致混乱。

function showLoading(message) {

  if (wx.showLoading) {

    // 基础库 1.1.0 微信6.5.6版本开始支持,低版本需做兼容处理

    wx.showLoading({

      title: message,

      mask: true

    });

  } else {

    // 低版本采用Toast兼容处理并将时间设为20秒以免自动消失

    wx.showToast({

      title: message,

      icon: 'loading',

      mask: true,

      duration: 20000

    });

  }

}

function hideLoading() {

  if (wx.hideLoading) {

    // 基础库 1.1.0 微信6.5.6版本开始支持,低版本需做兼容处理

    wx.hideLoading();

  } else {

    wx.hideToast();

  }

}

4、判断API参数或返回码

对于API的参数或者返回值有新增的参数,可以使用以下代码去进行判断。

wx.showModal({

    success: function(res) {

        if (wx.canIUse('showModal.cancel')) {

            console.log(res.cancel)

        }

    }

})

 

声明:文章"关于微信小程序兼容性相关问题浅析"为互诚科技—微信小程序开发公司的原创文章,转载请注明出处,谢谢合作!
标签:小程序开发文档
电话咨询:18011971195(黄先生)
在线留言:
微信扫码,关注我们
相关文章
  • 资讯类微信小程序运营的传播策略

    现在的微信小程序,不仅可以作为工具产品来使用,也可以作为一个推送资讯的平台来使用,不过由于小程序的入口比较特别,没有公众号的固定性,所以在运营推广上就需要去用符合它特色的方式去进行,而其中的内容传播也是需要有策略的。

  • 小程序开发文档:项目结构、页面结构、应用启动说明

    开发微信小程序,需要提前去学习了解的东西不少,比如它的运行环境、它的开发工具、它的项目结构、页面结构以及应用启动说明等等

  • 小程序相比起传统网络平台,有什么营销优势?

    传统的网络媒体平台做营销时,一般都是以PC端作为出发点来设计流程、界面,只有在PC端上才能看到这些营销消息,这样的限制性条件就会让营销效果大打折扣。而以微信小程序等为代表的新媒体营销平台,相对于PC端来说,就有更加符合现代发展趋势与市场需求的优势了,这些优势主要有以下几个方面:

  • 如何控制微信小程序宣传推广成本

    虽然微信小程序是在微信应用中去宣传推广的,由于微信的裂变传播以及庞大用户流量的支持,所以小程序在宣传推广的时候

  • 小程序的出现,是改变了生活还是改变了市场

    在微信生态圈的不断发展下,现在的微信用户生活已经快要与微信密不可分了,对其的依赖性越来越强。而微信小程序的出现,更是给这个影响打了一剂强心针,让微信生态的影响力不断扩大。因此,有人说,微信小程序改变了我们的生活,也有人说,小程序是在不断改变市场当中去发展的,这两种说法各有道理。

  • 微信小程序怎么做社群营销

    社群营销是一种网络推广中确定定向客户较好的方法,微信小程序的推广也可以通过社群营销去在社群中打响自己的知名度,让小程序的推广有个准确的承受群体,不让推广工作变成无用功。不过,对于微信小程序的社群营销,最首先要解决的就是如何去做的问题。