web性能优化 - 重排与重绘

重排与重绘

重排 [重构/回流/reflow]:
当DOM变化影响了节点的几何属性,浏览器需要重新计算节点的几何属性,并且页面中其他节点的可能受影响,这样渲染树就发生了改变并重新构造渲染树。这个过程称为重排。
引起方式:改变页面布局(width,height,left,top等)

重绘 [repaint或redraw] :
重绘是一个节点的外观发生改变的行为,例如改变color、outline等属性。
浏览器会根据节点的新属性重新绘制,使节点呈现新的外观。重绘不会带来重新布局,并不一定伴随着重排。
引起方式:在页面布局稳定情况下,改变颜色、背景色

两者关系:
重排会引起重绘,重绘不一定一起重排

两者对浏览器的影响:
提升浏览器渲染开支,降低浏览器性能,可视效果就是导致浏览器卡顿缓慢。

降低重排与重绘的手段与方式:

1.减少dom操作
例如:改变一个元素的样式,不要反复获取这个dom进行逐次的css样式修改,而是将dom元素存在变量中,将多个样式放在一个类名下,操作类名

//--css
.box { width:300px; height:200px; background:red; }
//---js
var oBox = document.getElementById('box');
oBox.className = 'box';

不要这么做

document.getElementById('box').style.width = 300+'px';
document.getElementById('box').style.height= 200+'px';
document.getElementById('box').style.backgroundColor = 'red';

2.将大量操作dom元素,引发重排的操作,在文档流外进行
添加10000个li

var oUl = document.getElementById('ul1');
var resultStr = '';
for(var i=0; i<1000; i++){
  var oLi = '<li>'+('hello world'+i)+'</li>';
  resultStr += oLi;
}
 oUl.innerHTML= resultStr;

不要这么做:

var oUl = document.getElementById('ul1');
for(var i=0; i<1000; i++){
  var oLi = document.createElement('li');
  oLi.innerHTML = 'hello world'+i;
  oUl.appendChild(oLi);
}

3.使用文档碎片做DOM操作

var oUl = document.getElementById('ul1');
var fragment = document.createDocumentFragment();
for(var i=0; i<1000; i++){
var oLi = document.createElement('li');
oLi .innerText = 'hello world'+i;
fragment.appendChild(oLi);
}
oUl.appendChild(fragment);

4.通过css方式,降低对文档流的重排
将需要反复操作,且每次操作都会引起重排的DOM元素,开始display设置为none
完整所有操作后,再讲display设置为block

var oUl = document.getElementById('ul1');
oUl.style.display = 'none';
for(var i=0; i<1000; i++){
  var oLi = document.createElement('li');
  oLi.innerHTML = 'hello world'+i;
  oUl.appendChild(oLi);
}
oUl.style.display = 'block';

5.使用cloneNode与replaceChild

var old = document.getElementById('mylist');
var clone = old.cloneNode(true); 
//如果传递给它的参数是 true,它还将递归复制当前节点的所有子孙节点。否则,只复制当前节点。
appendDataToElement(clone, data);
old.parentNode.replaceChild(clone, old);

6.使用transform 替代 position去完成动画,减少重排与重绘
chrome 调试工具 performance中查看 painting; 使用css3要比css2快3倍以上

//--css
#ul1 { left: 0; top: 0; position: absolute; width:100px; height: 100px; background: red; transition: all ease 0.5s;}
body { height: 800px;}
/* body:hover #ul1 { left: 300px; top: 300px;}  */
body:hover #ul1 { -webkit-transform: translate(300px,300px); transform: translate(300px,300px); }

//--html
<ul id="ul1"></ul>

7.给页面图片或者其父级设定一个尺寸
为页面中所有图片指定宽度和高度可以消除不必要的重排和重新绘,使页面渲染速度更快

  • 指定与图片本身相一致的尺寸、如果一个图片文件实际上的大小是60×60像素,不要在HTML或CSS里设置尺寸为30×30像素;提前作2套图,一个是缩略,一个是展示

8.将JS脚本放置最后面,较少阻塞,加快浏览器渲染(排版与绘制)速度
页面加载渲染过程

  • 解析HTML代码并生产一个DOM树
  • 解析CSS文件,顺序为:浏览器默认样式 => 自定义样式 => 页面内样式
  • 生产渲染树。与DOM树不同的是渲染树受样式影响,不包括不可见节点
  • 根据渲染树,浏览器就会在屏幕上绘制出渲染树上的所有节点
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 211,948评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,371评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,490评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,521评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,627评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,842评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,997评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,741评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,203评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,534评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,673评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,339评论 4 330
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,955评论 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,770评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,000评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,394评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,562评论 2 349

推荐阅读更多精彩内容