微信小程序:渲染流程、生命周期和触发顺序

微信小程序:渲染流程、生命周期和触发顺序,第1张

程序的生命周期分为 应用生命周期 、 页面生命周期

App() 必须在 app.js 中调用,必须调用且 只能调用一次 ,app.js中定义了一些应用的生命周期函数

(1)onLaunch: 初始化小程序时触发,全局只触发一次

(2)onShow: 小程序初始化完成或用户从后台切换到前台显示时触发

(3)onHide: 用户从前台切换到后台隐藏时触发

(4)onError: 小程序发生脚本错误,或者 api 调用失败时,会触发 onError 并带上错误信息

后台:点击左上角关闭,或者按了设备 Home 键离开微信,并没有直接销毁,而是进入后台

前台:再次进入微信或再次打开小程序,相当于从后台进入前台。

官方介绍 https://developers.weixin.qq.com/miniprogram/dev/reference/api/App.html

js文件中定义了一些页面生命周期函数,下面简述下这些生命周期函数的方法作用

(1)onLoad:首次进入页面加载时触发,可以在 onLoad 的参数中获取打开当前页面路径中的参数。

(2)onShow:加载完成后、后台切到前台或重新进入页面时触发

(3)onReady:页面首次渲染完成时触发

(4)onHide:从前台切到后台或进入其他页面触发

(5)onUnload:页面卸载时触发

官方介绍 https://developers.weixin.qq.com/miniprogram/dev/reference/api/Page.html

通过console.log验证它们的触发顺序

以上是对生命周期粗略的认识,如有不足请指正~

参考链接 https://www.jianshu.com/p/2e48f2468d5f

                                                                   列表渲染

1、wx:for

wx:for指令用于循环数组数据,生成组件。

循环出来的每一项通过item返回,每一项对应的索引,通过index返回。

    <view wx:for="{{songs}}" wx:key="index" class="items">

       <text>{{index}}--{{item.id}}--{{item.name}}</text>

    </view>

2、wx:key

wx:key="",设置每一项唯一的标识。循环列表时,添加wx:key的好处是,将来列表发生变化时重新渲染列表的损耗为更低。

                                                             条件渲染

条件渲染可以使用wx:if或hidden。

一般来说,wx:if 有更高的切换消耗而 hidden 有更高的初始渲染消耗。因此,如果需要频繁切换的情景下,用 hidden 更好,如果在运行时条件不大可能改变则 wx:if 较好。

1、wx:if

wx:if用于条件渲染:条件为真生成里面的内容,条件为假不会生成里面的内容。(每次重新生成内容)

也可以用wx:elif 和 wx:else 来添加一个 else 块。

  <view wx:if="{{typeID == 1}}"> 1 </view>

  <view wx:elif="{{typeID == 2}}"> 2 </view>

  <view wx:else> 3 </view>

2、hidden

hidden用于条件渲染:条件为真隐藏里面的内容,条件为假显示里面的内容。(每次切换样式)

  <view hidden="{{typeID!= 2}}"> 1 </view>

运行微信开发者工具

选择小程序项目

新建小程序项目

进入小程序的开发界面

在index.wxml页面中,添加一个按钮

名称为重新渲染

<button>重新渲染</button>

添加后的效果如图

给这个按钮添加事件

<button bindtap="onrefresh">重新渲染</button>

进入index.js文件

完成事件方法

在onrefresh中完成重新渲染的事件

, onrefresh:function(){

wx.showToast({

title: '开始重新渲染',

icon: 'success',

duration: 2000

})

this.onLoad()

}


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/12080821.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-20
下一篇 2023-05-20

发表评论

登录后才能评论

评论列表(0条)

保存