微信小程序——生命周期,生命周期的分类,页面生命周期,生命周期函数的分类,应用的生命周期函数,页面的生命周期函数,wxs脚本概述

news2024/11/16 15:26:32

一.生命周期

    • 什么是生命周期

生命周期( Life Cycle )是指一个对象从创建->运行->销毁的整个阶段,强调的是一个时间段。

例如:

.张三出生,表示这个人生命周期的开始

.张三离世,表示这个人生命周期的结束

.中间张三的一生,就是张三的生命周期

我们可以把每个小程序运行的过程,也概括为生命周期:

.小程序的启动,表示生命周期的开始

.小程序的关闭,表示生命周期的结束

.中间小程序运行的过程,就是小程序的生命周期

2.生命周期的分类

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

a.应用生命周期

.特指小程序从启动﹣>运行﹣>销毁的过程

b.页面生命周期

.特指小程序中,每个页面的加载->渲染->销毁的过程

其中,页面的生命周期范围较小,应用程序的生命周期范围较大,如图所示

3.什么是生命周期函数

生命周期函数:是由小程序框架提供的内置函数,会伴随着生命周期,自动按次序执行。

生命周期函数的作用:允许程序员在特定的时间点执行某些特定的操作。例如,页面刚加载的时候,可以在 onLoad 生命周期函数中初始化页面的数据。

注意:生命周期强调的是时间段,生命周期函数强调的是时间点。

4.生命周期函数的分类

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

1.应用的生命周期函数

.特指小程序从启动﹣>运行﹣>销毁期间依次调用的那些函数

2.页面的生命周期函数

.特指小程序中,每个页面从加载->渲染->销毁期间依次调用的那些函数

5.应用的生命周期函数

小程序的应用生命周期函数需要在app.js中进行声明,示例代码如下:

6.页面的生命周期函数

小程序的页面生命周期函数需要在页面.js文件中进行声明,示例代码如下:

onLoad(Object query)

页面加载时触发。一个页面只会调用一次,可以在 onLoad 的参数中获取打开当前页面路径中的参数。

onShow()

页面显示/切入前台时触发。

onReady()

页面初次渲染完成时触发。一个页面只会调用一次,代表页面已经准备妥当,可以和视图层进行交互。

注意:对界面内容进行设置的 API 如wx.setNavigationBarTitle,请在onReady之后进行。详见生命周期

onHide()

页面隐藏/切入后台时触发。 如 wx.navigateTo 或底部 tab 切换到其他页面,小程序切入后台等。

onUnload()

页面卸载时触发。如wx.redirectTowx.navigateBack到其他页面时。

二.WXS脚本-概述

    • 什么是wxs

wxs ( WeiXin Script )是小程序独有的一套脚本语言,结合 WXML ,可以构建出页面的结构

2.WXS的应用场景

wxml 中无法调用在页面的 js 中定义的函数,但是, wxml 中可以调用 Wxs 中定义的函数。因此,小程序中 Wxs 的典型应用场景就是"过滤器".

3.wxs和 JavaScript 的关系*

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

① wxs 有自己的数据类型

. number 数值类型、 string 字符串类型、 boolean 布尔类型、 object 对象类型、

. function 函数类型、 array 数组类型、

② wxs 不支持类似于ES6及以上的语法形式

date 日期类型、 regexp 正则

.不支持: let 、 const 、解构赋值、展开运算符、箭头函数、对象属性简写、 etc ....

. 支持: var 定义变量、普通 function 函数等类似于ES5的语法

③ wxs 遵循 CommonjS 规范

. module 对象

. require ()函数

. module . exports 对象

三.WXS脚本-基础语法

1.内嵌wxs脚本

Wxs 代码可以编写在 wxmi 文件中的 cwxs >标签内,就像 Javascript 代码可以编写在 html 文件中的< script >标签内一样。

wxml 文件中的每个< wxs ></ wxs >标盖,必须提供 module 属性,用来指定当前 woxs 的顿块名称,方便在 wxml 中访问模块中的成员:

2.定义外联的wxs脚本

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

3.使用外联的 wxs 脚本

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

其中:

. module 用来指定模块的名称

. src 用来指定要引入的脚本的路径,且必须是相对路径

示例代码如下:

四.WXS脚本-WXS的特点

    • 与javaScript不同

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

2.不能作为组件的事件回调

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

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

3.隔离性

隔离性指的是 wxs 的运行环境和其他 JavaScript 代码是隔离的。体现在如下两方面:

① wxs 不能调用 js 中定义的函数

② wXs 不能调用小程序提供的 API

4.性能好

.在 iOS 设备上,小程序内的 WXS 会比 JavaScript 代码快2~20倍

.在 android 设备上,二者的运行效率无差异

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/184671.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

单源最短路的建图方式(Dijkstra)

由于是复习&#xff0c;所以不会解释太多。 主要为Dijkstra的堆优化板子和朴素版&#xff08;看数据范围&#xff09; 再次看看时间复杂度[ n 为点数&#xff0c;m 为边数 ]&#xff1a;朴素版&#xff1a;O()&#xff0c;堆优化版&#xff1a;O( (nm)logm )。 目录 1.热浪&…

CS专业学习回顾

前言 起因是想清理一下github的仓库&#xff0c;没错是清理&#xff0c;之前fork了很多仓库学习代码&#xff0c;还有自己随便上传的一些代码&#xff0c;因为感觉没有留着的必要&#xff0c;博客多少可以review&#xff0c;这些早期写的代码&#xff0c;如洪水猛兽&#xff0…

java集合类-操作集合

Collections&#xff08;操作集合的工具类&#xff09; 该工具类里提供了大量方法对集合元素进行排序、查询和修改等操作&#xff0c;还提供了将集合对象1.设置为不可变、对集合对象实现同步控制等方法。自行看API即可。 2.有查找、替换集合元素的类方法。 有同步控制的方法&am…

使用 Python 深度学习方法对电影评论进行情绪预测

情感分析是一种自然语言处理问题&#xff0c;可以理解文本并预测潜在意图。 在本文中&#xff0c;你将了解如何使用 Keras 深度学习库将电影评论的情绪预测为正面或负面。 看完这篇文章&#xff0c;你会知道&#xff1a; 关于自然语言处理的 IMDB 情感分析问题以及如何在 Ke…

核心表结构

核心表结构目录概述需求&#xff1a;参考资料和推荐阅读Survive by day and develop by night. talk for import biz , show your perfect code,full busy&#xff0c;skip hardness,make a better result,wait for change,challenge Survive. happy for hardess to solve denp…

Android重新签名APK

前提已经配置好了Java环境。在要签名的apk文件目录路径位置&#xff0c;输入cmd&#xff0c;打开命令窗口。在命令窗口中输入jarsigner&#xff0c;有相应的提示。然后输入重新签名指令如下&#xff1a;jarsigner -verbose -keystore E:\tmc\keystore\androidsign.jks -signedj…

51单片机学习笔记-10IIC总线

10 I2C总线 [toc] 注&#xff1a;笔记主要参考B站江科大自化协教学视频“51单片机入门教程-2020版 程序全程纯手打 从零开始入门”。 10.1 AT24C02和I2C介绍 10.1.1 存储器介绍 图10-1 存储器分类 一般来说&#xff0c;RAM读写速度极快&#xff0c;但掉电丢失&#xff1b;而…

InfluxDB OSS v2.6.0安装使用小结(ubuntu Linux)

1 InfluxDB简介 InfluxDB是一款用Go语言编写的开源分布式时序、事件和指标数据库。 官网&#xff1a;https://www.influxdata.com 1.1 特色 InfluxDB的主要特色 1&#xff09;无结构&#xff08;无模式&#xff09;&#xff1a;可以是任意数量的列 2&#xff09;可拓展的 3&…

学习云原生的阅读书单

以下是我从豆瓣阅读上找到的书单 《云原生服务网格lstio》 《云原生操作系统Kubernetes》 《OpenShift云原生架构&#xff1a;原理与实践》

[oeasy]python0066_控制序列_光标位置设置_ESC_逃逸字符_CSI

光标位置 回忆上次内容 上次讲了 三引号的输出三引号中 回车和引号 都会 被原样输出\ 还是需要从 \\转义 黑暗森林 快被摸排清了 还有哪个 转义序列 没 研究过吗&#xff1f;&#x1f914; \e是 干什么的&#xff1f;&#x1f914; 回忆转义 转义转义 转化含义 \反斜杠(…

CnOpenData劳务外包企业工商注册基本信息数据

一、数据简介 随着我国社会主义市场经济的发展&#xff0c;劳务市场中的用工方式也朝着多样化方向演变&#xff0c;劳务外包正是现代化人力资源管理和企业生产实际结合的一种独特的新模式。 在劳务外包过程中&#xff0c;企业将人事管理的部分或者全部工作外包给一个专门的服务…

Hadoop 复习 ---- chapter01【大数据概念】

Hadoop 复习 ---- chapter01【大数据概念】1. 什么是大数据大数据的简介从IT过渡到DT2. Hadoop生态系统工具HADOOPHBASEHIVESTORMZooKeeperSqoopMAHOUT1. 什么是大数据 大数据的简介 指“无法由现有软件工具进行提取、存储、搜索、共享、分析和处理的庞大而复杂的数据集”。 通…

【软件测试】某城商行手机银行授权漏洞分析黑客攻击,测试优化手段......

目录&#xff1a;导读前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09;前言 问题描述 据报道&am…

【FreeRTOS】详细讲解FreeRTOS的软件定时器及通过示例讲述其用法

软件定时器 所谓定时器&#xff0c;也就可以类比生活中人们常用的闹钟&#xff0c;可以单次响铃提醒&#xff0c;也可以间隔固定时间响铃提醒&#xff1b;与FreeRTOS定时器不同的是周期不同&#xff0c;FreeRTOS的周期更加短&#xff0c;一般使用毫秒(ms)、秒(s)。   软件定时…

Python的数字类型、布尔类型和运算优先级

文章目录1.数字类型1.1分类1.2整数1.3浮点数1.4复数2.数字运算符2.1运算符表格2.2 运算符 //3.divmod&#xff08;&#xff09;函数4.abs&#xff08;&#xff09;函数4. int()&#xff0c;float() 和 complex() 函数5.pow&#xff08;&#xff09;函数和运算符 **6.布尔类型6.…

NB-IoT的低功耗特性原理解说

什么是NB-IoT NB-IoT的中文名叫窄带蜂窝物联网(Narrow Band Internet of Things)&#xff0c;NB-IoT网络是基于4G网络演进过来的&#xff0c;所以它在上行和下行的复用技术上还是沿用了4G的OFDMA和SC-FDMA。NB-IoT有三大特性&#xff1a;速率低&#xff0c;成本低&#xff0c;…

电脑风扇声音大怎么办?具体原因以及解决措施,快速解决

​很多小伙伴使用台式电脑&#xff0c;使用的时间长了&#xff0c;电脑机箱里的风扇就会发出一些噪音&#xff0c;很影响小伙伴的整体使用体验。电脑风扇声音大怎么办&#xff1f;具体的原因以及解决措施有哪些&#xff1f;下面就跟着小编一起来看看吧。 一、电脑风扇声音大的原…

数据挖掘,计算机网络、操作系统刷题笔记39

数据挖掘&#xff0c;计算机网络、操作系统刷题笔记39 2022找工作是学历、能力和运气的超强结合体&#xff0c;遇到寒冬&#xff0c;大厂不招人&#xff0c;可能很多算法学生都得去找开发&#xff0c;测开 测开的话&#xff0c;你就得学数据库&#xff0c;sql&#xff0c;orac…

Kibana最新版8.6.1安装教程

Kibana 让您能够自由地选择如何呈现自己的数据。不过借助 Kibana 的交互式可视化&#xff0c;您可以先从一个问题出发&#xff0c;看看能够从中发现些什么。查看完整的 Kibana 功能列表https://www.elastic.co/cn/kibana/featuresKibana的下载地址&#xff1a;https://www.elas…

有状态/无状态认证

文章目录一、什么是有状态认证&#xff1f;二、什么是无状态认证&#xff1f;&#xff08;token&#xff09;三、无状态分布式认证解决方案一、什么是有状态认证&#xff1f; 有状态认证&#xff0c;即服务端需要记录每次会话的客户端信息&#xff0c;从而识别客户端身份&#…