微信客户端给小程序所提供的环境,称为宿主环境。小程序借助宿主环境提供的能力,可以完成许多普通网页无法完成的功能。
1 渲染层和逻辑层
首先,我们来简单了解下小程序的运行环境。小程序的运行环境分成渲染层和逻辑层,其中 WXML 模板和 WXSS 样式工作在渲染层,JS 脚本工作在逻辑层。
小程序的渲染层和逻辑层分别由2个线程管理:渲染层的界面使用了 WebView 进行渲染;逻辑层采用 JsCore 线程运行 JS 脚本。一个小程序存在多个界面,所以渲染层存在多个 WebView 线程,这两个线程的通信会经由微信客户端(Native )做中转,逻辑层发送网络请求也经由 Native 转发,小程序的通信模型,如图 1 所示。

2 程序与页面
微信客户端在打开小程序之前,会把整个小程序的代码包下载到本地。
紧接着通过 app.json 的 pages 字段就可以知道你当前小程序的所有页面路径:

这个配置说明在这个项目内定义了两个页面,分别位于 pages/index/index 和 pages/logs/logs。而写在 pages 字段的第一个页面就是这个小程序的首页(打开小程序看到的第一个页面)。
于是微信客户端就把首页的代码装载进来,通过小程序底层的一些机制,就可以渲染出这个首页。
小程序启动之后,在 app.js 定义的 App 实例的 onLaunch 回调会被执行:
App({
onLaunch: function () {
// 小程序启动之后 触发
}
})
比如,我们在此打印日志:

保存后,就会在微信开发者工具中的 Console 标签下,看到相应输出:

注意: 整个小程序只有一个 App 实例,是全部页面共享的。
接下来我们简单看看小程序的一个页面是怎么写的。
我们可以观察到 pages/logs/logs 下,包括了4种类型的文件:

微信客户端会先根据 logs.json 配置生成一个界面,顶部的颜色和文字你都可以在这个 json 文件里边定义好。紧接着客户端就会装载这个页面的 WXML 结构和 WXSS 样式。最后客户端会装载 logs.js,你可以看到 logs.js 的大体结构为:
Page({
data: { // 参与页面渲染的数据
logs: []
},
onLoad: function () {
// 页面渲染后 执行
}
})
Page 是一个页面构造器,这个构造器就生成了一个页面。在生成页面的时候,小程序框架会把 data 数据和 index.wxml 一起渲染出最终的结构,于是就得到了我们看到的小程序的样子。
在渲染完界面之后,页面实例就会收到一个 onLoad 的回调,我们可以在这个回调中加入需要的逻辑。
3 组件
小程序提供了丰富的基础组件给开发者,开发者可以像搭积木一样,组合各种组件拼合成自己的小程序。
就像 HTML 的 div, p 等标签一样,在小程序里边,我们只需要在 WXML 写上对应的组件标签名字就可以把该组件显示在界面上,例如,假设我们需要在界面上显示地图,只需要这样写即可:
<map></map>
效果:

使用组件的时候,还可以通过属性传递值给组件,让组件可以以不同的状态去展现,例如,我们希望地图一开始的中心的经纬度是上海,那么你需要声明地图的 longitude(中心经度) 和 latitude(中心纬度)两个属性:
<map longitude="121.47" latitude="31.23"></map>

组件的内部行为也会通过事件的形式让开发者可以感知,例如用户点击了地图上的某个标记。
也可以通过 style 或者 class 来控制组件的外层样式,以便适应我们的界面宽度高度等等。
4 API
为了让开发者可以很方便的调起微信提供的能力,例如获取用户信息、微信支付等等,小程序提供了很多 API 给开发者去使用。
要获取用户的地理位置时,只需要:
wx.getLocation({
type: 'wgs84',
success: (res) => {
var latitude = res.latitude // 纬度
var longitude = res.longitude // 经度
}
})
注意: 必须先在 app.json 中声明权限,然后才可使用:
"permission": {
"scope.userLocation": {
"desc": "通过您的位置信息,可以更好地为您服务๑乛◡乛๑"
}
},
desc 属性用于确认框中,需要告知用户的具体说明内容。
点击“获取地理位置”按钮后,会弹出确认框:

点击确定后,就可以获取到用户的经纬度信息:

如果想要调用微信扫一扫能力,只需要:
wx.scanCode({
success: (res) => {
console.log(res)
}
})
注意: 多数 API 的回调都是异步,我们需要处理好代码逻辑的异步问题。
网友评论