taro 重新加载小程序_Taro 小程序 性能优化

手上有个小程序项目,遇到了挺多坑,有关性能方面的,时间间隔一段时间了,突然发现都快忘完了,赶紧在此记录一下,

一 页面加载耗时

这是首次性能检测时页面加载情况:

页面最长渲染居然达到了900多毫秒!!!,看到问题出在setData,去了解了一下原生小程序的setData渲染工作原理,原来setData里面的所有数据都会被转成字符串,然后字符串又转换成JS脚本,然后页面根据JS脚本去渲染页面,所以我们频繁的去更新setData就会造成页面不断的重排重绘,

了解问题所在,就从根源解决问题,第一点就从数据的获取赋值的地方着手,一方面在需要渲染列表的地方用高阶函数map,只返回需要的数据,如:

let list = data.map(item => {

// item 中可能包含很多不需要的字段 如:{id,name,a,b,c,d,c,d,g....}

//而我们只需要id和name

return {

id: item.id,

name: item.name

}

})

console.log(list) // 输出 [{id:'xx',name:'xx'}]

另一方面在设置state值时,多个值可以合并设置 如:

this.setState({title:'页面标题'})

this.setState({pageC

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值