标签:
页面退出的时候取消监听绑定在页面的监听事件
清除定时器
推荐级别:强烈
每使用一次 setTimeout / setInterval 时必须要在页面消毁时与其相匹配的 clearTimeout / clearInterval 调用,否则可能会导致持续地内存泄露。
反例
export default {
onInit() {
setTimeout(() => {
// todo something
}, 1000)
setInterval(() => {
// todo something
}, 1000)
},
onDestroy() {},
}
正例
export default {
onInit() {
this.t1 = setTimeout(() => {
// todo something
}, 1000)
this.t2 = setInterval(() => {
// todo something
}, 1000)
},
onDestroy() {
// 解除内存占用
clearTimeout(this.t1)
clearInterval(this.t2)
},
}
取消监听事件
推荐级别:强烈
页面中使用的监听类接口(如 feature、C2JS 等),页面退出时必须清除监听。原因同上。
反例
export default {
onInit() {
brightness.subscribe({
callback: (data) => {},
})
busineseApp.on('onReceive', callback)
},
onDestroy() {},
}
正例
export default {
onInit() {
brightness.subscribe({
callback: (data) => {},
})
busineseApp.on('onReceive', callback)
},
onDestroy() {
brightness.unsubscribe()
busineseApp.removeAllListener('onReceive')
},
}
Native 模块释放相关资源
通过 requireModule
申请的资源,如果跟页面绑定,请在页面销毁的时候在页面 onDestroy()
中同步销毁,以免造成内存泄漏。
标签: 来源:
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。