web前端性能优化总结

Css优化总结

      对于css的优化可以从网络性能和css语法优化两方面来考虑。

Css性能优化方法如下:

1、css压缩

Css 压缩虽然不是高端的知识,但是很有用。其原理也很简单,就是把我们css代码中没有用的空白符等删除,达到缩减字符个数的目的。

 

压缩css代码的工具:

A、YUI compressor,可以在线压缩css和js代码。

B、gulp自动化构建工具,中的gulp-minify-css。

 

2、gzip压缩

Gzip是一种流行的文件压缩算法,现在应用的十分广泛,尤其实在Linux这个平台上,这个不止是对css,当应用Gzip压缩一个文本时,效果是非常明显的。大约可以减少70%以上的文件大小(这取决于文件中的内容)。

在没有 gzip压缩的情况下,web服务器直接把html页面、css脚本以及js脚本发送到浏览器,而支持gzip的浏览器在本地进行解压和解码,并显示原文件。这样我们传输的文件字节数减少了,自然可以达到网络性能优化的目的。Gzip压缩需要服务器的支持,所以需要在服务器端进行配置。

 

3、合写css(通过少些css属性来达到减少css字节吗的目的)

例子:

background:#000 url(image.jpg) top left no-repeat;

font:font-style   font-weight    font-size  font-familiy;

margin:5px 10px 20px 15px;

padding:5px;

border:2px 5px 10px 3px;

border-top:2px 5px 10px 3px;

 

4、利用继承

Css的继承机制可以帮我们在一定程度上缩减字节数,我们知道css很多属性可以继承,即在父容器设置了默认属性,子容器会默认也使用这些属性。

可继承的属性举例:

所有元素都可以继承的属性:visibility 、cursor

内联元素和块元素可以继承的属性:

Letter-spacing、word-spacing、white-space、line-height、color、font、font-family、font-size、font-style、font-variant、font-weight、text-decoration、text-transform、direction。

块状元素可以继承的属性:

Text-indent、text-align;

列表元素可以继承的属性:

List-style、list-style-type、list-style-position、list-style-image

 

表格元素可以继承的属性:

Border-collapse

 

不可以继承的属性:

Displaymarginborderpaddingbackgroundheightmin-heightmax-heightwidthmin-widthmax-widthoverflowpositionleftrighttopbottomz-indexfloatcleartable-layoutvertical-alignpage-break-afterpage-break-beforeunicode-bidi

 

5、抽离、拆分css,不加载所有css

抽离原则:在很多时候,我们把页面通用的css写到了一个文件,这样加载一次后,就可以利用缓存,但这样做兵不适合所有的场景。所以抽离拆分的时候要考虑好。

 

6、css放在head中,减少repaint和reflow

Css方法在页面的顶部,有利于优化的原因???

当浏览器从上到下一遍下载html生成dom tree,一边根据浏览器默认以及现有css生成render tree来渲染页面。当遇到新的css的时候下载并结合现有css重新生成render tree。则刚才的渲染功能就全废了。当我们把所有css放在页面的顶部,就没有重新渲染的过程了。

 

脚本中应该尽量少用repaint和reflow:

Reflow:当dom元素出现隐藏/显示,尺寸变化。位置变化的时候,逗号让浏览器重新渲染页面,以前的渲染工作白费了。

Repaint:当元素的背景颜色,边框颜色变化的时候,不会引起reflow的变化,是会让浏览器重新渲染该元素。

 

7、避免使用通配符或隐式通配符:visible.

8、避免层级或过度限制css(css是从右向左解析的)

A、不要用标签或class来限制id。

#test .info   /div #test这都属于画蛇添足

Id已经可以唯一而且快速的定位到一个元素了。

 

B、不要用标签限制class

Div .info  不好

在css代码编写中,如果直接使用class不能达到目的,一般是class设计出现了问题,css需要重构。

C、尽量使用最具体的类别,避免使用后代选择器,在css选择器中,后代选择器非但没有加快css查找,反而后代选择器是css中耗费最贵的。

 

 

JavaScript优化总结

1、避免全局查找

在一个函数中尽量将全局对象存储为局部变量来查找,因为访问局部变量的数要更快一些。

function(){

alert(window.location.href+window.location.host);

}

修改为:

funciton(){

var location=window.location;

alert(location.href+location.host);

}

 

2、定时器

如果针对的是不断运行的代码,不应该使用setTimeout,而应该使用setInterval。因为setTimeout每一次都会初始化一个定时器。而setInterval只会在开始的时候初始化一个定时器。

var timeoutTimes=0;

function timeout(){

      timeoutTimes++;

      if(timeoutTimes<10){

           setTimeout(timeout,10);

      }

}

修改为:

var intervalTimes=0;

function interval(){

      intervalTimes++;

      if(intervalTimes>=10){

           clearInterval(interval)''

      }

}

var interval = setInterval(interval,10);

 

3、字符串连接

如果需要连接多个字符串,应该少使用+=:

s+=a;s+=b;s+=c;

修改为:

s+=a+b+c;

而如果是收集字符串,比如多次对同一个字符进行+=操作的话,最好使用一个缓存,使用js数组来收集,最后join方法连接起来。

var buf=[];

for(var i=0;i<100;i++){

      buf.push(i.toString());

}

var all=buf.join("");

 

4、避免with语句

和函数类似,with语句会创建自己的作用域,因此会增加其中执行的代码的作用域链的长度。犹豫额外的作用域链的查找,在with语句中执行的代码肯定会比外面执行的低吗要慢,在能不使用with语句的时候,尽量不要使用with语句。

with(a,b,c,d){

      property1=1;

      property2=2;

}

修改为:

var obj=a.b.c.d;

obj.property1=1;

obj.property2=2;

 

5、数字转为字符串

一般用“”+1来将数字转为字符串,虽然看起来比较丑一点,但事实上这个效率最高。

(“”+1)>String()>.toString()>new String()

 

6、浮点数转化为整型

很多人喜欢使用pareseInt(),其实parseInt()是用于将字符串转为数字,而不是浮点数和整型之间的转换。我们应该使用的是Math.floor()或Math.round();

 

7、多个类型声明

所有变量可以使用单个var语句来声明,这样就是组合在一起的语句,以减少整个脚本的执行时间。

var   A=1,

       B=2,

       C=3;

 

8、使用直接量

var aTest=new Array();//var aTest=[]

var aTest=new Object();//var aTest={}

var reg=new RegExp();//var reg=/ /;

创建具有特殊性的一般对象,也可以使用字面量。

var oFruit=new O();

oFruit.color="red";

oFruit.name="apple";

应改为

varoFruit={color:"red",name:'apple'}

 

9、使用DocumentFragment优化多次的append

一旦需要跟新DOM,请考虑使用文档碎片来构建结构,然后再添加到现有的文档中。

for(var i=0;i<1000;i++){

      varel=document.createElement('p');

      el.innerHTML=i;

      document.body.append(el);

}

应该改为

varfrag=document.createDocumentFragment();

for(var i=0;i<1000,i++){

      varel=document.createElement('p');

      el.innerHTML=i;

      frag.append(el);

}

document.body.appendChild(frag);

 

10、使用一次innerHTML复制代替构建dom元素。

对于大的dom更改,使用innerHTML要比使用标准的dom方法创建同样的dom结构快的多。

varfrag=document.createDocumentFragment();

for(var i=0;i<1000;i++){

      varel=document.createElement('p');

      el.innerHTML=i;

      frag.appendChild(el);

}

document.body.appendChild(frag);

应该改为

var html=[];

for(var i=0;i<1000;i++){

      html.push('

'+i+"

");

}

document.body.innerHTML=html.join("");

 

11、使用firstChild和nextSibling代替childNodes遍历dom元素。

var nodes=element.childNodes;

for(var i=0,l=nodes.length;i

      varnode=nodes[i];

}

应该改为

var node=element.firstChild;

while(node){

      node.node.nextSibling;

}

 

12、删除dom节点

删除dom节点之前,一定要删除注册在该节点上的事件,不管是observe方式还是用attachEvent方式注册的事件。否则将会产生无法回收的内存。另外,removeChild和innerHTML=‘’两者之间尽量选择后者,因为在内存泄漏工具中监测的结果是用removeChild无法有效的释放dom节点。

 

13、简化终止条件

由于每次循环过程,都会计算终止条件。所以必须保证他尽可能的快。也就是避免属性查找或其他操作。最好是将循环控制量保存到局部变量中,也就是说对数组或列表对象遍历的时候,提前将length保存到局部变量中,避免循环的每一步重复取值。

varlist=document.getElementsByTagName('p');

for(var i=0;i

 

}

应该改为

for(var i=0,l=list.length;i

     

}

 

14、使用后测试循环

在js中,我们使用for(;;),while(),for(in)三种循环。for(in)的效率极差。因为他需要查询散列键,只要可以,就应该尽量少用。

for(;;)和while循环,while优于for(;;),可能for(;;)结构问题,需要经常的跳转。do..while更好。

 

15、尽量少用eval函数

使用eval函数相当于在运行时,再次调用解释引擎对内容进行运行,需要消耗大量时间,而且使用eval带来的安全性问题也是不容忽视的。

 

16、不要给setTimeout或setInterval传递字符串参数。

var num=0;

setTimeout(num++,10);

应该改为

var num=0;

function addNum(){

      num++;

}

setTimeout(addNum,10);

 

17、缩短否定检测

if(oTest!="#ff0000"){}

if(oTest!=null){}

if(oTest!=false){}

以上都不太好

if(!oTest){这个比较好}

 

18、可以用三目运算符替换条件分支,可以提高效率。

 

 

Web性能优化

1、避免坏请求

有时候页面中的html或css会向服务器请求一个不存在的资源,比如图片或者html文件,这会造成浏览器与服务器之间过多的往返请求。

类似于:

浏览器:“我需要这个图像”

服务器:“我没有这个图像”

浏览器:“你确定吗?这个文档说你有”

服务器:“真的没有”

这个降低页面加载速度。因此检查坏连接很有必要。可通过Google的PageSpeed工具,找到问题后,补充相当资源文件或者修改资源链接地址即可。

 

2、避免css@import

使用@import方法引用css文件可能会带来一些影响页面加载速度的问题。比如导致文件按顺序加载(一个加载完成后才会加载另一个),无法并行加载;

检查工具:css delivery

查到@import url(“style.css”)

就替换为:

 

3、避免使用document.write

在js中,可以使用document.write。在网页上显示内容或者调用外部资源,而通过此方法,浏览器采取一些多余的步骤(下载资源,读取资源)。运行js来了解需要做什么,调用其他资源时,需要重新在执行一次这个过程。由于浏览器之前不知道要显示什么,所以会降低页面加载的速度。

要知道,任何能够被document.write调用的资源,都可以通过html调用。这样速度会更快

document.write('');

改为

 

4、合并多个外部css文件

网站中每使用一个css文件,都会让你的页面加载速度慢一点。可以css delivery工具,来检测页面代码中css文件。然后通过复制粘贴合并成一个。

 

5、合并多个外部js文件

可以用resource check来检测页面中所引用的js文件数,然后可以通过复制粘贴的方法将多个文件合并成一个。

 

6、通过css sprites来整合图像

若页面中有6个小图像,那么浏览器在显示时会分别下载,你可以通过css sprites将这些图像合并成为一个,可以减少页面加载所需要的时间。

Css sprites两个步骤:整合图像,定位图像

 

7、延迟js加载

浏览器在执行js代码时,会停止处理页面。当页面中很多js文件或者代码要加载时,将导致严重的延迟。尽管可以使用defer,异步或将js代码放自爱页面底部来延迟js的加载。但这些都不是一个好的解决方案。

好方法

 

8、启用压缩/Gzip

使用gzip对html和css文件进行压缩,通常可以大约节省50%到70%,这样加载页面只需要更少的带宽和更少的时间。

 

9、如果你的css和js较小,可以将css和js内嵌到html页面中,这样可以减少页面加载所需要的文件数,从而加快页面的加载。

 

10、用minify css压缩css代码

 

11、尽量减少dns查询次数

当浏览器和服务器建立链接时,它需要进行dns解析,将域名解析为ip地址,然而,一旦客户端需要执行dns lookup时,等待时间将会取决于域名服务器的有效响应速度。

虽然所有的isp的dns服务器都能缓存域名和ip地址映射表。但如果缓存的dns记录过期了而需要更新,则可能需要遍历多个dns节点,有时候需要通过全球范围内来找到可信任的域名服务器,一旦域名服务器工作繁忙,请求解析时,就需要排队则进一步延时等待时间。

所有减少dns查询次数很重要,页面加载就尽量避免额外耗时,为了减少dns查询次数,最好的解决方法就是在页面中减少不同的域名请求的机会、

可通过request checker工具来检测页面中存在多少请求后,进行优化。

 

12、尽量减少重定向

有时候为了特定需求,需要在网页中使用重定向。重定向的意思是,用户的原始请求(如请求A)被重定向到其他的请求(如请求B);

网页中使用重定向会造成网站性能和速度下降,因为浏览器访问网址是一连串的过程,如果访问到一半,而跳转到新的地址,就会重复发起一连串的过程,这将浪费很多时间。所有我们尽量避免重定向。Google建议

A、       不要链接到一个包含重定向的页面

B、       不要请求包含重定向的资源

 

13、优化样式表和脚步顺序

Style标签和样式表调用代码应该放置在js代码的前面,这样可以使页面的加载速度加快。

 

14、避免js阻塞渲染

浏览器在遇到一个引入外部js文件的

你可能感兴趣的:(web性能,CSS,JS,web性能,安全及缓存)