返回列表 发新帖

前端工程师必读:网站前端性能优化最佳方案

362.2k 8
swmozowtfl 发表于 2015-7-9 23:23:58|湖北 | 查看全部 阅读模式
一个网站影响用户访问的最大部分是前端的页面。网站可以划分为:前端和后台。后台可以理解成是用来实现网站的功能的,而前端是属于功能的表现。然如除了后台需要在性能上做优化外,其实前端的页面更需要在性能优化上下功夫,只有这样才能给我们的用户带来更好的用户体验。) }, n( H3 m$ G  }( C
如今浏览器能够实现的特性越来越多,并且网络逐渐向移动设备转移,使我们的前端代码更加紧凑,如何优化,就变得越来越重要了。 开发人员普遍会将他们的代码习惯优先于用户体验。但是很多很小的改变可以让用户体验有个飞跃提升,所以任何一点儿小小的优化都会提升你网站的性能。 前端给力的地方是可以有许多种简单的策略和代码习惯让我们可以保证最理想的前端性能。说了这么多,那么我们应该如何对我们前端的页面进行性能优化呢?
% a% E) z) z$ g5 g8 e而前端开发工作者可以控制的是什么呢?。前端的页面主要包括xhtml,css,js。其实xhtml就是现实中所谈到的内容,页面的内容:文字,图片,flash,视频等。4 _2 r. Y" j' T: `1 h) \8 i0 D
网站前端性能优化最佳方案1:使用documentfragments或innerhtml取代复杂的元素注入
+ B3 G8 r. t! C  V/ J% }8 Hdom操作在浏览器上是要付税的。尽管性能提升是在浏览器,dom很慢,如果你没有注意到,你可能会察觉浏览器运行非常的慢。这就是为什么减少创建集中的dom节点以及快速注入是那么的重要了。
4 U7 G/ Q% m* P2 Z7 s& [" M- W  e现在假设我们页面中有一个<ul>元素,调用ajax获取json列表,然后使用javascript更新元素内容。通常,程序员会这么写:
+ b3 q/ U6 l4 F& j+ L5 Cvar list = document.queryselector('ul');2 y- f6 G: S8 h1 l% m5 y, S
ajaxresult.items.foreach(function(item) {
- d7 I, s) `# g) H2 ~ // 创建<li>元素
( W5 V! M9 T* L3 h* s( N7 e var li = document.createelement('li');* Y, D( R% X9 r1 ~; z* S
li.innerhtml = item.text;! _0 K' e5 b5 W
// <li>元素常规操作,例如添加class,更改属性attribute,添加事件监听等, B+ s9 O* E  n7 H
// 迅速将<li>元素注入父级<ul>中
% B0 V5 }- U2 F2 W+ f list.apppendchild(li);
) L. }8 q( o5 V});
! m( U2 M! N7 X上面的代码其实是一个错误的写法,将<ul>元素带着对每一个列表的dom操作一起移植是非常慢的。如果你真的想要 使用document.createelement,并且将对象当做节点来处理,那么考虑到性能问题,你应该使用documentfragement。 # V  z8 i) U% u+ u+ G
documentfragement 是一组子节点的“虚拟存储”,并且它没有父标签。在我们的例子中,将documentfragement想象成看不见的<ul>元素,在 dom外,一直保管着你的子节点,直到他们被注入dom中。那么,原来的代码就可以用documentfragment优化一下:
& J9 f% e8 A$ k% U8 z1 Xvar frag = document.createdocumentfragment();
* I/ M. V- {9 L* ]0 v) m( ]ajaxresult.items.foreach(function(item) {1 q, ^- Y' W5 r) G* j, H
// 创建<li>元素7 L6 ~* m* v6 y0 n" ~
var li = document.createelement('li');
3 I* t: u& D' {+ X3 A+ o li.innerhtml = item.text;( G5 X, f& S& j5 k) G2 G# q
// <li>元素常规操作5 B- z& T. \' ~4 g; U; N
// 例如添加class,更改属性attribute,添加事件监听,添加子节点等& B) N% Y% x1 E) {6 T0 N
// 将<li>元素添加到碎片中
) \8 [% ^3 h( E4 D* P frag.appendchild(li);, C$ |8 h' ]# a( ]- @5 _/ ~% u" v7 c# t
});3 y' j8 ~( R7 N( A+ v: O
// 最后将所有的列表对象通过documentfragment集中注入dom2 g, }. c  [! l+ f9 i
document.queryselector('ul').appendchild(frag);2 P; P) O. j# n+ C
为documentfragment追加子元素,然后再将这个documentfragment加到父列表中,这一系列操作仅仅是一个dom操作,因此它比起集中注入要快很多。
3 ?; I5 {  A1 R如果你不需要将列表对象当做节点来操作,更好的方法是用字符串构建html内容:
% h5 ^9 T6 e! X, evar htmlstr = '';) J& v; F0 P4 E% x. }- q
ajaxresult.items.foreach(function(item) {3 ~( ?2 U9 z3 h5 w( V- z$ E8 i
// 构建包含html页面内容的字符串
6 l( |' F: ^+ J0 M& o4 h- h htmlstr += '<li>' + item.text + '</li>';
: U; j* B" v9 U* v9 }- F});
: k" z0 C' u5 \5 ]: p- n// 通过innerhtml设定ul内容( D3 \7 T7 p1 O- h8 K
document.queryselector('ul').innerhtml = htmlstr;
1 p, U- M# x0 `1 s. n这当中也只有一个dom操作,并且比起documentfragment代码量更少。在任何情况下,这两种方法都比在每一次迭代中将元素注入dom更高效。/ w6 G: i$ T* A+ \, C6 _
网站前端性能优化最佳方案2:高频执行事件/方法的防抖. I$ G8 ]# x; A) [' z/ o; t
通常,开发人员会在有用户交互参与的地方添加事件,而往往这种事件会被频繁触发。想象一下窗口的resize事件或者是一个元素的onmouseover事件 - 他们触发时,执行的非常迅速,并且触发很多次。如果你的回调过重,你可能使浏览器死掉。 ( h+ Y2 A( z4 A) e9 S! o
这就是为什么我们要引入防抖。 " Y9 k$ c. {9 O! @
防抖可以限制一个方法在一定时间内执行的次数。以下代码是个防抖示例:
% q) C+ W- r- X" i. g5 ]// 取自 underscorejs 实用框架3 I) C8 i) D' m; r! t7 |
function debounce(func, wait, immediate) {
# h$ V7 x: L1 ~ var timeout;* q$ I9 D5 u' s9 ]4 [, D5 X
return function() {3 T, ^# p, Z. z8 ~
var context = this, args = arguments;
5 I4 e& k4 }, B" Y( x( V var later = function() {/ U$ O7 t7 M% Y' j
timeout = null;
# ~+ c7 V+ |& J8 j9 q% V if (!immediate) func.apply(context, args);
) W" N$ Y1 p% p6 d/ [6 d };
$ X3 T6 _' k) J: s& S/ c var callnow = immediate && !timeout;
, T. ~! R# q4 B1 s! q cleartimeout(timeout);( u; P+ T. c% r4 }
timeout = settimeout(later, wait);1 h& Z" Y0 A+ `* Q5 n( F. \; d
if (callnow) func.apply(context, args);
( T) H" T* P( U1 ~$ ]0 ~ };
. e5 w4 S, r* V }( q8 m2 {1 s+ d1 c
// 添加resize的回调函数,但是只允许它每300毫秒执行一次' W3 j. R4 P: B7 S2 |5 h
window.addeventlistener('resize', debounce(function(event) {
' i: \" Y4 U. ~) G: l! g/ E( X$ d // 这里写resize过程
- c5 F$ c1 f, g) J: u$ v}, 300));. V4 u0 U/ O) B( [7 h; `  Z5 E
debounce方法返回一个方法,用来包住你的回调函数,限制他的执行频率。使用这个防抖方法,就可以让你写的频繁回调的方法不会妨碍用户的浏览器!
5 s* K% t& _5 d- `! j. [
+ E3 f0 @1 J# c/ f! d% r$ S6 F! o更多网页制作信息请查看: 网页制作

回复|共 8 个

seazvyt 发表于 2016-3-12 11:39:26|美国 | 查看全部
看你快沉底了~~~~~~
wwdu926a 发表于 2016-3-12 11:39:40|INNA | 查看全部
什么什么啊??
tohme 发表于 2016-3-12 11:39:46|美国 | 查看全部
还没崇拜过谁呢,满足一下愿望吧,谢谢!
gevaemaidovef 发表于 2016-3-12 11:39:49|Reserved | 查看全部
呵呵 我可不敢~~~~
wwzcdenleclv 发表于 2016-3-18 18:43:57|罗马尼亚 | 查看全部
回来了 呵呵刚才在斗地主那 ~~~~
effoggikeftor 发表于 2016-3-18 18:44:13|美国 | 查看全部
哈哈 我支持你
gevaemaidovef 发表于 2016-3-18 18:44:32|Reserved | 查看全部
我去看看 网络上的事 我不是很会 哎
Mqokjdvq 发表于 2016-3-18 18:44:35|塞尔维亚 | 查看全部
你该这么说~~

回复

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

得知互动是一个融创意、设计、开发、营销、生活、互联网于一体的专业交流分享平台。
Copyright © 2026 站长技术交流论坛|互联网技术交流平台|Ai技术交流平台 版权所有 All Rights Reserved. Powered by Discuz! X5.0 鄂ICP备15006301号-5|鄂公网安备 42018502006730号
关灯 在本版发帖 扫一扫添加QQ客服 返回顶部
快速回复 返回顶部 返回列表