关于小程序自定义组件observer 频繁触发导致内存溢出

关于小程序自定义组件observer 频繁触发导致内存溢出,第1张

组件 使用 observer 的目的是 组件某一个属性改哗歼斗变,获得监听,改友处理想要的数据。

但是,直接改变 properties 下的属性 可能存在乱磨内存溢出的情况,这个时候可以考虑,重新给组件挂载一个值,

在编写表单的时候,因为有一个省市区的选择器重复用到,所以想拎出来当一个组件,同时后面又增加需求,这个表单页面展示时,先查数据,有的话要展隐森示

但是这时我从后台拿到数组,发现传进组件的数据,接收到了却明携李没有展示出来,看了其他博客,说是渲染问题:

picker里面的参数在data里已经完成初始化了

所以结果就是value对应的是data里面初始化的值,初始化的值为空,自然默认值只能是第一个。

我这里在组件中使用observers解决的

另外,不是组件激迟,表单页面上直接使用picker组件也有这个问题,从后台拿到数据,即时使用了setData修改picker 的index,数据也没有展示出来,我的解决方式:

对原生微信小程序不是很熟,仅供参考

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

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


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

原文地址: https://outofmemory.cn/yw/8214240.html

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

发表评论

登录后才能评论

评论列表(0条)

保存