1、用户点击入口后,百度 App 会加载智能小程序的代码包;
2、解压并获取其中的 app.json ;
3、根据框架机制,智能小程序框架在加载完成代码包之后,会启动 pages 中的第一项,并渲染为首次看到的页面;
4、智能小程序启动后,开始调用 app.js 中预设的生命周期方法。
|
在一个百度智能小程序中,只有一个 App 的实例(开发者可以用这个实例定义多个 Page 共享的变量)。
这部分是每个智能小程序页面的展现模板,类似于 Web 开发中的 HTML ,SWAN 模板中使用的标签均为 SWAN 组件规定的标签。
|
百度智能小程序_基础数据绑定
|
|
循环
开发者可以通过在元素上添加s-for
指令,来渲染一个列表:
语法
|
|
条件
开发者可以通过在元素上添加s-if
指令,来在视图层进行逻辑判断:
|
|
百度智能小程序_事件
事件处理
开发者可以使用bind: + 事件名
来进行事件绑定
|
|
目前支持的事件类型有:
类型 | 触发条件 |
---|---|
touchstart | 手指触摸开始 |
touchmove | 手指触摸后进行移动 |
touchend | 手指触摸结束 |
touchcancel | 手指触摸动作被打断,如来电提醒等 |
tap | 手指触摸后马上离开动作 |
事件对象
当开发者绑定方法到事件,事件触发时,SWAN 会给触发的方法传递事件对象,事件对象因事件不同而不同,目前基础的事件对象结构为:
属性 | 类型 | 说明 |
---|---|---|
type | String | 事件类型 |
currentTarget | Object | 事件触发的属性集合 |
dataset
开发者可以在组件中自定义数据,并在事件发生时,由 SWAN 所在事件对象中,传递给绑定函数。
示例代码:
|
|
touches
开发者在接收到触摸类事件后,在事件对象上,可以接收到当前停留在屏幕上的触摸点。
Touch 对象
属性 | 类型 | 描述 |
---|---|---|
pageX , pageY | Number | 距离文档左上角的距离,横向为 X,纵向为 Y |
clientX , clientY | Number | 距离屏幕视口左上角距离,横向为 X,纵向为 Y |
CSS 结尾的样式文件,类似于常规 CSS,用以渲染界面时进行样式描述。
SWAN 智能小程序中,JS 文件是控制交互逻辑的动态语言。
如,在 SWAN 模板中书写了以下代码:
|
在 JS 中可以对于视图中的行为进行监听,并触发界面的变化。
|
Tips:
1、书写 SWAN App 的逻辑层请使用 JavaScript 。
2、逻辑层将数据进行更新后,会触发视图更新。
3、在 app.js 中使用 App 方法、在页面 JS 中使用 Page 方法,来进行页面的逻辑管理。
4、可以在 SWAN 命名空间下,使用各种 API 端能力。
5、框架中不可使用 window, document 等 Web 能力。
框架以栈的形式维护了当前的所有页面。 当发生路由切换的时候,页面栈的表现如下:
路由方式 | 页面栈表现 |
---|---|
初始化 | 新页面入栈 |
打开新页面 | 新页面入栈 |
页面重定向 | 当前页面出栈,新页面入栈 |
页面返回 | 页面不断出栈,直到目标返回页,新页面入栈 |
Tab 切换 | 页面全部出栈,只留下新的 Tab 页面 |
getCurrentPages() 函数用于获取当前页面栈的实例,以数组形式按栈的顺序给出,第一个元素为首页,最后一个元素为当前页面。
Tip:
不要尝试修改页面栈,会导致路由以及页面状态错误。
路由方式
对于路由的触发方式以及页面生命周期函数如下:
路由方式 | 触发时机 | 路由前页面 | 路由后页面 |
---|---|---|---|
初始化 | 智能小程序打开的第一个页面 | onLoad, onShow | |
打开新页面 | 调用 API swan.navigateTo 或使用组件 | onHide | onLoad, onShow |
页面重定向 | 调用 API swan.redirectTo 或使用组件 | onUnload | onLoad, onShow |
页面返回 | 调用 API swan.navigateBack 或使用组件 或用户按左上角返回按钮 | onUnload | onShow |
Tab 切换 | 调用 API swan.switchTab 或使用组件 或用户切换 Tab | 各种情况请参考下表 | |
重启动 | 调用 API swan.reLaunch 或使用组件 | onUnload | onLoad, onShow |
Tab 切换对应的生命周期(以 A、B 页面为 Tabbar 页面,C 是从 A 页面打开的页面,D 页面是从 C 页面打开的页面为例):
当前页面 | 路由后页面 | 触发的生命周期(按顺序) |
---|---|---|
A | A | Nothing happend |
A | B | A.onHide(), B.onLoad(), B.onShow() |
A | B(再次打开) | A.onHide(), B.onShow() |
C | A | C.onUnload(), A.onShow() |
C | B | C.onUnload(), B.onLoad(), B.onShow() |
D | B | D.onUnload(), C.onUnload(), B.onLoad(), B.onShow() |
D(从转发进入) | A | D.onUnload(), A.onLoad(), A.onShow() |
D(从转发进入) | B | D.onUnload(), B.onLoad(), B.onShow() |
Tips:
1、navigateTo, redirectTo 只能打开非 tabBar 页面。
2、switchTab 只能打开 tabBar 页面。
3、reLaunch 可以打开任意页面。
4、页面底部的 tabBar 由页面决定,即只要是定义为 tabBar 的页面,底部都有 tabBar。
5、调用页面路由带的参数可以在目标页面的 onLoad 中获取。
百度智能小程序_Page
Page() 函数用来注册一个页面。接受一个 object 参数,其指定页面的初始数据、生命周期函数、事件处理函数等。
object 参数说明:
属性 | 类型 | 描述 |
---|---|---|
data | Object | 页面的初始数据 |
onLoad | Function | 监听页面加载的生命周期函数 |
onReady | Function | 监听页面初次渲染完成的生命周期函数 |
onShow | Function | 监听页面显示的生命周期函数 |
onHide | Function | 监听页面隐藏的生命周期函数 |
onUnload | Function | 监听页面卸载的生命周期函数 |
onPullDownRefresh | Function | 监听用户下拉动作 |
onReachBottom | Function | 页面上拉触底事件的处理函数 |
onShareAppMessage | Function | 用户点击右上角转发 |
onError | Function | 错误监听函数 |
其他 | 不限 | 开发者可以添加任意的函数或数据到 object 参数中,在页面的函数中用 this 可以访问 |
示例:
|
智能小程序框架,会将同页面的 .swan 文件与 .js 中定义的 Page 对象中的 data ,进行组合渲染。
智能小程序中提供了丰富多样的组件,开发者可以在 .swan 文件中,使用预设好的组件,拼装完成自己的智能小程序的页面。
如:使用 slider 组件
|
即可在页面上展示一个 slider 组件。
也可以在 slider 组件上绑定事件,在相应的组件事件发生时,得到回调与组件信息:
|
|
如showToast
:
|
也有很多挂载在 Page 对象与 SWAN 上的方法,如 createCanvasContext ,在 SWAN 对象与 Page 对象上均有。所以,你可以这样用:
|
也可以这样用:
|
但是推荐使用第一种方法,可以在当前 Page 上精准查找,避免一些问题。具体方法的挂载,在 API 章节 会有详细介绍。