码迷,mamicode.com
首页 > Web开发 > 详细

Web前端性能优化

时间:2018-01-17 12:27:34      阅读:183      评论:0      收藏:0      [点我收藏+]

标签:理解   就会   网页   完全   图片大小   服务   http请求   交换   音乐   

一、CSS方面:

1.精简css文件

  移除额外的空格;细微优化等,减小文件体积。

2. 高效使用HTML标签和CSS样式
  HTML是一门标记语言,使用合理的HTML标签前你必须了解其属性,比如Flow Elements,Metadata Elements ,Phrasing Elements。比较基础的就是得知道块级元素和内联元素、盒模型、SEO方面的知识。
  CSS是用来渲染页面的,也是存在渲染效率的问题。CSS选择符是从右向左进行匹配的,这里对css选择符按照开销从小到大的顺序梳理一下:
  ID选择符 #box
  类选择符 .box
  标签 div
  伪类和伪元素 a:hover

  body .box .border ul li p strong span{color:#000}
  以上都是对HTML和CSS非常糟糕的使用方法。
  当页面被触发引起回流(reflow)的时候,低效的选择符依然会引发更高的开销,所以请避免低效。

3. 请正确理解 Repaint 和 Reflow,尽可能限制Reflow的影响范围。

  Repaint(重绘)就是在一个元素的外观被改变,但没有改变布局(宽高)的情况下发生,如改变visibility、outline、背景色等等。
  Reflow(重排)就是DOM的变化影响到了元素的几何属性(宽和高),浏览器会重新计算元素的几何属性,会使渲染树中受到影响的部分失效,浏览器会验证DOM树上的所有其它结点的visibility属性,这也是Reflow低效的原因。如:改变窗囗大小、改变文字大小、内容的改变、浏览器窗口变化,style属性的改变等等。如果Reflow的过于频繁,CPU使用率就会噌噌的往上涨。
  减少性能影响的办法:
  上面提到通过设置style属性改变结点样式的话,每设置一次都会导致一次reflow,所以最好通过设置class的方式; 有动画效果的元素,它的position属性应当设为fixed或absolute,这样不会影响其它元素的布局;如果功能需求上不能设置position为fixed或absolute,那么就权衡速度的平滑性。
总之,因为 Reflow 有时确实不可避免,所以只能尽可能限制Reflow的影响范围。

二、JS方面:

1.精简js文件

  JavaScript的压缩,直接减少下载的文件体积。

2.请减少对DOM的操作

  对DOM操作的代价是高昂的,这在网页应用中的通常是一个性能瓶颈。修改和访问DOM元素会造成页面的Repaint和Reflow,循环对DOM操作更是罪恶的行为。所以请合理的使用JavaScript变量储存内容,考虑大量DOM元素中循环的性能开销,在循环结束时一次性写入。减少对DOM元素的查询和修改,查询时可将其赋值给局部变量

3. 使用JSON格式来进行数据交换
  JSON是一种轻量级的数据交换格式,采用完全独立于语言的文本格式,是理想的数据交换格式。同时,JSON是 JavaScript原生格式,这意味着在 JavaScript 中处理 JSON数据不需要任何特殊的 API 或工具包。
  与XML序列化相比,JSON序列化后产生的数据一般要比XML序列化后数据体积小,所以在Facebook等知名网站中都采用了JSON作为数据交换方式。

三、图片方面

1.压缩图片大小

  1.缩小图片分辨率;
  2.改变图片格式;
  3.降低图片保存质量。

2.合并图片(css sprites)

  把许多图片放到一张大图片里面,通过CSS来显示图片的一部分。

四、其它方面

1.减少HTTP请求

  在浏览器(客户端)和服务器发生通信时,就已经消耗了大量的时间,尤其是在网络情况比较糟糕的时候,这个问题尤其的突出。
一个正常HTTP请求的流程简述:如在浏览器中输入"www.xxxxxx.com"并按下回车,浏览器再与这个URL指向的服务器建立连接,然后浏览器才能向服务器发送请求信息,服务器在接受到请求的信息后再返回相应的信息,浏览器接收到来自服务器的应答信息后,对这些数据解释执行。
而当我们请求的网页文件中有很多图片、CSS、JS甚至音乐等信息时,将会频繁的与服务器建立连接,与释放连接,这必定会造成资源的浪费,且每个HTTP请求都会对服务器和浏览器产生性能负担。
  网速相同的条件下,下载一个100KB的图片比下载两个50KB的图片要快。所以,请减少HTTP请求。
  解决办法:
  合并图片(css sprites),合并CSS和JS文件;图片较多的页面也可以使用 lazyLoad 等技术进行优化。

2.将CSS和JS放到外部文件中引用,CSS放头,JS放尾

  引入外部文件好处是显而易见的,而且是项目稍稍复杂一点的时候就有必要了这样做了。易维护、易扩展,方便管理和重复利用。

  在浏览器在执行JavaScript代码时,不能同时做其它事情,即<script>每次出现都会让页面等待脚本的解析和执行(不论JavaScript是内嵌的还是外链的),JavaScript代码执行完成后,才继续渲染页面。这个也就是JavaScript的阻塞特性。因为这个阻塞的特点,建议把JavaScript代码放到</body>标签以前,这样既能有效的防止JavaScript的阻塞,又能使得页面的HTML结构能更快的释放。

3. 注意控制Cookie大小和污染

  因为Cookie是本地的磁盘文件,每次浏览器都会去读取相应的Cookie,所以建议去除不必要的Coockie,使Coockie体积尽量小以减少对用户响应的影响;
  使用Cookie跨域操作时注意在适应级别的域名上设置coockie以便使子域名不受其影响;
  Cookie是有生命周期的,所以请注意设置合理的过期时间,合理地Expire时间和不要过早去清除coockie,都会改善用户的响应时间。

Web前端性能优化

标签:理解   就会   网页   完全   图片大小   服务   http请求   交换   音乐   

原文地址:https://www.cnblogs.com/superlizhao/p/8301923.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!