Web前端性能优化:JavaScript细节篇

前言

MDove:最近业务非常的忙,android的学习文章先稍稍歇一歇。

上期给大家带来了HTML、CSS、JS优化,这期给大家带来页面加载速度优化。优化部分也经常出现在面试题中,希望这篇文章能给大家日常开发、面试带来帮助。本期内容请记住一个核心:JavaScript很快,DOM很慢

正文

一、用户看到页面之前都经历了什么

检查缓存

DNS服务器通过域名查找对应的web服务器的ip地址

三次握手机制、四次挥手机制

HTTP请求

返回资源

二、页面渲染过程

页面加载过程

说正事之前先说几点:

以现有的通用显示器为例,帧率大多为60fps,即一秒钟60帧,这是一个什么概念呢,就是一秒钟的动画是由60幅静态图片连在一起形成的。60fps是动画播放比较理想,比较基础的要求。

我们所说的页面卡了,就是页面失真了,或者掉帧了,一秒钟没有60个画面了,看起来不流畅了

产生这种情况的原因就是页面在渲染某些帧时所花的时间较长,导致停留在这些帧的时间较长,所以画面卡顿了。

JavaScript=>Style=>Layout=>Paint=>Composite=>Reflow?=>Repaint?

渲染DOM树和CSSOM树

JavaScript规则合并DOM树和CSSOM树行程Render Tree * 遍历渲染树开始布局,计算每个节点的位置大小信息,将Render Tree的每个节点绘制(composite)在屏幕上

reflow: 元素的几何尺寸发生了改变,需要重新验证并计算渲染树,是渲染树的一部分或者全部发生了变化

repaint: 屏幕的一部分重画,不影响整体布局,比如某个CSS的背景色变了,但元素的几何尺寸和位置不变

三、页面渲染过程优化

针对dom节点的显示隐藏进行优化

(1)display:none 的节点不会被加入Render Tree,而visibility: hidden 则会,所以,如果某个节点最开始是不显示的,设为display:none是更优的。

(2)display:none 会触发 reflow,而 visibility:hidden 只会触发 repaint,因为没有发现位置变化。

(3)有些情况下,比如修改了元素的样式,浏览器并不会立刻reflow 或 repaint 一次,而是会把这样的操作积攒一批,然后做一次 reflow,这又叫异步 reflow 或增量异步 reflow。但是在有些情况下,比如resize 窗口,改变了页面默认的字体等。对于这些操作,浏览器会马上进行 reflow。

dom深度尽量浅

减少行内css和js的使用

合适的选择器,避免后代选择器,通配符选择器

css选择器匹配:从右往左,最后一个选择器被称为关键选择器,最后一个选择器越特殊,需要匹配的次数越少

减少layout

layout是比较耗时的操作,要减少页面重绘。能用transform就不用position/width/height做动画,还要减少layout的影响范围

避免强制性同步布局//如果有一组 DOM 元素,我们需要读取它们的宽度,并设置其高度与宽度一致

for(let i = 0,len = divs.length; i

let width = divs[i].clientWidth;

divs[i].style.height = width + 'px';

}

//执行这段代码就引起了强制性同步布局(forced synchonous layout),在每次迭代开始的时候都会进行重新计算布局,这是很昂贵的操作,千万要避免--------------------------------------------------------------

//分离读与写

let widthArray = [];

for(let i = 0,len = divs.length; i

let width = divs[i].clientWidth;

widthArray.push(width);

}

for(let i = 0,len = divs.length; i

divs[i].style.height = widthArray[i] + 'px';

}

异步加载js文件并合并js文件

涉及到一个浏览器并发请求数量的问题:

例如chorme浏览器针对每一个域最多只能有6个TCP连接

基于端口数量和线程切换开销的考虑,浏览器不可能无限量的并发请求

并非越大越好,基于良知和默契的考虑,保护浏览器和服务器更好的性能

迅雷、暴风影音等可以修改电脑的最大连接数

四、加快页面的打开速度

页面开启速度主要指标:白屏时间,首屏时间,页面加载完成时间,所有资源加载完成

减少渲染堵塞(js、css)

两种处理方式有什么区别呢?head标签中的外链脚本会影响DOM构建和页面图片加载,特别是脚本很多时,所以需要加上defer避免阻塞。但是加上defer属性的资源加载的优先级会降为最低,甚至比图片还低,高优先级的资源加载顺序会优于低优先级的加载。如果页面的展示比交互重要,需要马上加载出来,可以加上defer,否则还是把JS文件放在body后面就行了

将script标签放在body后面

给script标签添加defer属性,异步加载,延后执行script资源

优化图片:

使用响应式图片

延时加载图片

按需加载图片

使用雪碧图,图标字体

结合使用SVG图

压缩和缓存

gzip压缩、Cache-control、Etag

五、增强用户体验

加载loading框

增加过度动画效果

合理及时的错误处理

人性化的等待交互

尾声

生命不息,编程不止,干就完了。

最后,如果有想一起学习web前端,HTML5及JavaScript的可以来一下我的前端群539738200,好友都会在里面交流,分享一些学习的方法和需要注意的小细节,每天也会准时的讲一些前端的炫酷特效,及前端直播课程学习

如果想看到更加系统的文章和学习方法经验可以关注的微信号:‘web前端技术圈’或者‘webxh6’关注后回复‘2018’可以领取一套完整的学习视频

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

推荐阅读更多精彩内容