RN-性能优化 (一)
来源:互联网 发布:统赢慢走丝编程软件 编辑:程序博客网 时间:2024/06/14 19:40
前人种树后人乘凉http://www.jianshu.com/p/11f38925f5ad
原文地址
一、异步逐层渲染。
React Native 虽然一直标榜媲美Native的体验,但实际使用下来,其渲染性还是非常低效,基于ScrollView和ListView两大容器,在渲染上,相当于web端的table布局,需要等整个大table渲染完成才显示页面,也就是说,当容器内有大量的子元素,其白屏时间会非常长。
二、实现shouldComponentUpdate方法
如上第一点,逐层渲染提升打开时间,但是也会导致component重复渲染,也就是执行了大量无用的diff算法。虽然React里引以为傲的diff算法非常高效,但是执行数量达到一定程度后,也会带来非常大的影响。那么可使用shouldComponentUpdate来控制component的渲染次数。
如果确定该组件渲染完后 无需再次更新 ,即这个组件是一个 静态组件,那么可以直接return false
shouldComponentUpdate(){ return false}
三、使用setNativeProps方法
setNativeProps方法可以理解为web的直接修改dom。使用该方法修改View、Text等RN自带的组件,则不会触发组件的componentWillReceiveProps、shouldComponentUpdate、componentWillUpdate等组件生命周期中的方法。
建议频繁更新的操作,如slider、tabs切换等拖曳操作时,使用setNativeProps来更新属性,会获得意想不到的性能体验。
//修改文本输入框的 属性值 this.refs.textInputRefer.setNativeProps({ editable:false });//修改文本输入框的 style this.refs.text2.setNativeProps({ style:{ color:'blue', fontSize:30 } });
四、不要使用阴影效果
React Native 里面的 shadow相关的样式,是非常耗性能的css属性。这在web上,以前android 2.0年代,也是一样耗性能的css属性之一。如果需要使用阴影效果,建议使用图片来代替反而性能更好一些。
五、最小化DOM
React Native里虚拟dom结构越复杂,则越低效。如果层级结构大于5级,则要考虑下优化了。这没啥技巧,纯靠经验及硬实力。
六、组件粒度化
如何更好的划分组件粒度,这需要合理的对组件进行更细粒度的划分,区分出静态组件及动态组件。
- RN-性能优化 (一)
- RN-性能优化 (二)
- RN-性能优化 (三)
- RN-性能优化 (四)
- 【性能优化】续一
- unity性能优化(一)
- 优化Flash性能(一)
- oracle性能优化(一)
- java性能优化一
- MySQL性能优化(一)
- 性能优化tips(一)
- Android性能优化(一)
- Mysql性能优化一
- Mysql性能优化一
- Mysql性能优化一
- Android 性能优化一
- Mysql性能优化一
- ios性能优化一
- Webstorm2017的激活及汉化
- redis基本命令
- [jsp]out.print()和response.getWriter().print()的区别
- 总结关于在ScrollView里面嵌套listView的一些坑
- POJ2443:Set Operation(bitset)
- RN-性能优化 (一)
- MySQL基础知识点八
- swustoj格雷码(0605)
- 西瓜书学习笔记(二)
- 2017.4.20课
- windows上安装MXNet
- TensorFlow实战13:实现策略网络(强化学习一)
- Liunux 编程遇到的SIGBUS信号
- RN-性能优化 (二)