微信小程序快速入门03

简介: 微信小程序快速入门03



前言

本文讲诉:生命周期、WXS脚本。


一、生命周期

  • 生命周期(Life Cycle) 是指一个对象从创建 -> 运行 ->销的整个阶段,强调的是一个时间段。例如:
  • 张三出生,表示这个人生命周期的开始
  • 张三离世,表示这个人生命周期的结束
  • 中间张三的一生,就是张三的生命周期
  • 我们可以把每个小程序运行的过程,也概括为生命周期:
  • 小程序的启动,表示生命周期的开始
  • 小程序的关闭,表示生命周期的结束
  • 中间小程序运行的过程,就是小程序的生命周期
  • 在小程序中,生命周期分为两类,分别是
  • 应用生命周期
  • 特指小程序从启动->运行->销毁的过程
  • 页面生命周期
  • 特指小程序中,每个页面的加载->渲染->销毁的过程
  • 其中,页面的生命周期范围较小,应用程序的生命周期范围较大,如图所示:

生命周期函数

  • 生命周期函数:是由小程序框架提供的内置函数,会伴随着生命周期,自动按次序执行。
  • 生命周期函数的作用:允许程序员在特定的时间点,执行某些特定的操作。例如,页面刚加载的时候,可以在onLoad 生命周期函数中初始化页面的数据。
  • 注意:生命周期强调的是时间段,生命周期函数强调的是时间点。

分类:

小程序中的生命周期函数分为两类,分别是:

  • 应用的生命周期函数
  • 特指小程序从启动->运行->销毁期间依次调用的那些函数
  • 页面的生命周期函数
  • 特指小程序中,每个页面从加载->渲染->销毁期间依次调用的那些函数

应用的生命周期函数

页面的生命周期函数

二、WXS脚本

  • WXS (WeiXin Script)是小程序独有的一套脚本语言,结合WXML,可以构建出页面的结构。
  • 应用场景
  • wxml 中无法调用在页面的js 中定义的函数,但是,wxml中可以调用 wxs 中定义的函数。因此,小程序中wxs的典型应用场景就是“过滤器”。

wxs和JavaScript的关系

虽然 wxs 的语法类似于JavaScript,但是 wxs和JavaScript 是完全不同的两种语言:

  • wxs 有自己的数据类型
  • number 数值类型、string 字符串类型、object 对象类型、boolean 布尔类型、
  • function 函数类型、array 数组类型、date 日期类型、regexp 正则
  • wxs 不支持类似于 ES6 及以上的语法形式
  • 不支持:let、const、解构赋值、展开运算符、箭头函数、对象属性简写、etc…
  • 支持:var 定义变量、普通function 函数等类似于ES5的语法
  • wxs 遵循 CommonJS 规范
  • module 对象
  • require()函数
  • module.exports 对象

基础语法

内嵌wxs脚本

  • wxs代码可以编写在 wxml文件中的< wxs > 标签内,就像Javascript 代码可以编写在 html文件中的< script >标签内一样。
  • wxml 文件中的每个< wxs ></ wxs> 标签,必须提供 module 属性,用来指定当前 wxs 的模块名称,方便在wxml中访问模块中的成员:
<view>{{m1.toUpper(useranme)}}</view>
<wxs module="m1">
  module.exports.toUpper = function(str) {
    return str.toUpperCase()
  }
</wxs>

定义外联的wxs脚本

wxs 代码还可以编写在以.wxs 为后缀名的文件内就像javascript 代码可以编写在以js 为后缀名的文件中一样。示例代码如下:

function toLower(str) {
  return str.toLowerCase()
}
module.exports = {
  toLower: toLower
}

使用外联的wxs脚本

在wxml中引入外联的 wxs 脚本时,必须为 标签添加 module 和 src 属性,其中

  • module 用来指定模块的名称
  • src 用来指定要引入的脚本的路径,且必须是相对路径

示例代码如下:

<view>{{m2.toLower(country)}}</view>
<wxs src="../../utils/tools.wxs" module="m2">

wxs的特点

与JavaScript 不同

为了降低 wxs (WeiXin Script)的学习成本,wx 语言在设计时借大量鉴了JavaScript 的语法。但是本质上wxs和JavaScript 是完全不同的两种语言!

不能作为组件的事件回调

wxs典型的应用场景就是"过滤器"经常配合 Mustache 语法进行使用,例如:

但是,在 wxs 中定义的函数不能作为组件的事件回调函数。例如,下面的用法是错误的:

隔离性

  • 隔离性指的是wxs的运行环境和其他JavaScript代码是隔离的。体现在如下两方面:
  • wxs不能调用is中定义的函数
  • wxs不能调用小程序提供的AP

性能好

  • 在ios 设备上,小程序内的 WXS 会比 JavaScript 代码快 2 ~ 20 倍
  • 在 android 设备上,二者的运行效率无差异

总结

以上就是小程序快速入门讲解。

相关文章
|
5月前
|
小程序
微信小程序快速入门 - 10分钟入门
微信小程序快速入门 - 10分钟入门
46 0
|
6月前
|
小程序 开发工具 Android开发
微信小程序开发工具的使用,各个配置文件详解,小程序开发快速入门(二)
微信小程序开发工具的使用,各个配置文件详解,小程序开发快速入门(二)
538 0
|
6月前
|
小程序 JavaScript 开发工具
微信小程序开发工具的使用,各个配置文件详解,小程序开发快速入门(一)
微信小程序开发工具的使用,各个配置文件详解,小程序开发快速入门(一)
278 1
|
6月前
|
JSON 小程序 JavaScript
微信小程序快速入门02(含案例)
微信小程序快速入门02(含案例)
|
6月前
|
小程序 前端开发 JavaScript
微信小程序快速入门01(含案例)
微信小程序快速入门01(含案例)
195 1
|
6月前
|
JSON 移动开发 小程序
微信小程序快速入门开发指南(三)
微信小程序快速入门开发指南(三)
|
23天前
|
JSON 小程序 JavaScript
uni-app开发微信小程序的报错[渲染层错误]排查及解决
uni-app开发微信小程序的报错[渲染层错误]排查及解决
358 7
|
23天前
|
小程序 JavaScript 前端开发
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
430 1
|
1月前
|
小程序 前端开发 测试技术
微信小程序的开发完整流程是什么?
微信小程序的开发完整流程是什么?
97 7
ly~
|
2月前
|
存储 供应链 小程序
除了微信小程序,PHP 还可以用于开发哪些类型的小程序?
除了微信小程序,PHP 还可用于开发多种类型的小程序,包括支付宝小程序、百度智能小程序、抖音小程序、企业内部小程序及行业特定小程序。在电商、生活服务、资讯、工具、娱乐、营销等领域,PHP 能有效管理商品信息、订单处理、支付接口、内容抓取、复杂计算、游戏数据、活动规则等多种业务。同时,在企业内部,PHP 可提升工作效率,实现审批流程、文件共享、生产计划等功能;在医疗和教育等行业,PHP 能管理患者信息、在线问诊、课程资源、成绩查询等重要数据。
ly~
75 6
下一篇
无影云桌面