前端性能解决方案
1、服务器端采用CDN加速,缩短客户端访问物理路径
2、尽量减少DOM元素的重排和重绘
重排的概念
浏览器下载完页面中的所有组件(HTML、Javascript、css、图片)之后会解析生成两个内部数据结构(DOM树和渲染树),DOM树表示页面结构,渲染树表示DOM节点如何显示,重排是DOM元素的几何属性变化,DOM树的结构变化,渲染树需要重新渲染
重绘的概念
重绘是一个元素外观的改变所触发的浏览器行为,例如改变visibility,outline,背景色等属性,浏览器会根据元素的新属性重新绘制,使元素呈现新的外观。由于浏览器的流布局,对渲染树的计算通常只需要遍历一次就可以完成。但table及其内部元素除外,它可能需要多次计算才能确定好其在渲染树中节点的属性值,比同等元素要多花两倍的时间,这就是我们尽量避免使用table布局页面的原因之一。
重排和重绘的关系
重绘不会引起重排,但是重排一定会引起重绘,一个元素的重排会引起一系列的反应,甚至会触发整个文档的重排和重绘,性能代价很高昂的。
什么情况下会触发重排?
A、页面渲染初始化的时候(这个是无法避免的)
B、浏览器窗口改变尺寸
C、元素尺寸改变时
D、元素位置改变时
E、元素内容改变时
F、添加或删除可见的元素
重排优化的方法
A、将多次改变样式属性的操作合并成一次操作,减少DOM访问
B、如果要批量添加DOM,可以先让元素脱离文档流,操作完后再带入文档流,这样只会触发一次重排(fragment 元素的应用)
C、将需要多次重排的元素,position属性设为absolute或fixed,这样此元素就脱离了文档流,它的变化不会影响到其他元素,例如有动画效果的元素最好设置为绝对定位
D、由于display属性为none的元素不在渲染树中,对隐藏的元素操作不会引发其他的元素的重排,如果要对一个元素进行复杂的操作时,可以先隐藏它,操作完成后再显示,这样只在隐藏和显示的时候触发了重排
E、在内存中多次操作节点,完成后再添加到文档中去,例如要异步获取表格数据,渲染到页面中,可以先取得数据后再内存中构建整个表格的HTML片段,再一次性添加到文档中,而不是循环添加每一行。