微信小程序开发自学笔记 —— 八、小程序基础库的更新迭代

小程序基础库的更新迭代

小程序基础库

小程序的运行环境是分成渲染层和逻辑层的,在渲染层可以用各类组件组建界面的元素,在逻辑层可以用各类API来处理各种逻辑,组件、API其实都是小程序基础库进行包装提供的,基础库的职责还要处理数据绑定、组件系统、事件系统、通信系统等一系列框架逻辑,才能让整个小程序有序的运作起来。

小程序的基础库是JavaScript编写的,它可以被注入到渲染层和逻辑层运行。

基础库载入时机

为了让小程序业务代码能够调用wx.navigateTo等API以及组件,就需要在启动小程序后先载入基础库,接着再载入业务代码。

小程序的渲染层和逻辑层是两个线程管理,渲染层WebView层注入的称为WebView基础库,逻辑层注入的称为AppService基础库。

所有小程序在微信客户端打开的时候,都需要注入相同的基础库 。

小程序的基础库会被提前内置在微信客户端。这样做的好处有两点:

  1. 降低业务小程序的代码包大小。
  2. 可以单独修复基础库中的Bug,无需修改到业务小程序的代码包
基础库的版本号

小程序基础库版本号使用 semver 规范,格式为 Major.Minor.Patch,其中Major、Minor、Patch均为整数。

在小程序中,可以通过wx.getSystemInfo()或者wx.getSystemInfoSync()方法获取小程序版本号

let info = wx.getSystemInfoSync()
console.log("小程序基础库版本号为:" + info.SDKVersion)

异常

JS运行异常

一般语法错误以及运行时错误,浏览器都会在Console里边显示对应的错误信息,以及出错的文件、行号、堆栈信息。

捕捉JS异常的方法

在WebView层有两种方法可以捕捉JS异常:

  1. try, catch方案。你可以针对某个代码块使用try,catch包装,这个代码块运行时出错时能在catch块里边捕捉到。
  2. window.onerror方案。也可以通过window.addEventListener(“error”, function(evt){}),这个方法能捕捉到语法错误跟运行时错误,同时还能知道出错的信息,以及出错的文件,行号,列号。

小程序基础库在WebView侧使用window.onerror方案进行捕捉异常,在逻辑层AppService侧通过把App实例和Page实例的各个生命周期等方法包裹在try-catch里进行捕捉异常。同时在App构造器里提供了onError的回调,当业务代码运行产生异常时,这个回调被触发,同时能够拿到异常的具体信息,开发者自己根据业务情况处理对应的容错逻辑。

基础库的更新

基础库版本变动

小程序的很多能力需要微信客户端来支撑,例如蓝牙、直播能力、微信运动等,可以说,小程序基础库的迭代离不开微信客户端的发布。

推送基础库过程

小程序基础库的迭代速度非常快,但是基础库的变更会影响到所有小程序的运行,如果基础库出现重大Bug没有及时发现时,会引起很多小程序无法正常使用,所以在更新基础库时要谨慎。

首先,在正式灰度推送新版本基础库前,内部要有严格的自动化测试流程,保证已有的测试用例全部能通过,同时还会在带有最新版本库的测试机上运行访问量较高的一些小程序并检测他们是否存在一些白屏等异常现象。

接着进行灰度推送,一般灰度时长是12个小时,遇到一些重大代码改动时可能灰度时间会更久。推送过程中,观察监控曲线是否有异动,仔细分析对应的上报日志是否存在致命的错误。

灰度推送完成后,发布新能力的文档,此时也要关注微信开发者社区的Bug反馈,根据情况再决定是否要推送Patch版本进行一些Bug的修复。

你可能感兴趣的:(微信小程序,微信小程序,小程序,javascript)