web页面性能优化

web前端页面性能优化

  网站的划分通常为二:前端和后台。咱们能够理解成后台是用来实现网站的功能的,好比:实现用户注册,用户可以为文章发表评论等等。而前端呢?javascript

其实应该是属于功能的表现。而且影响用户访问体验的绝大部分来自前端页面。网站前端的用户体验决定了用户是否想要去使用网站的功能,而网站的功css

能决定了用户是否会一票否决前端体验。若是前端优化得好,他不只能够为企业节约成本,并且由于加强的用户体验,还给公司带来更多的用户。那么我html

们应该如何对咱们前端的页面进行性能优化呢?前端

浏览器访问优化

  浏览器请求处理流程以下图:java

 

一、减小http请求,合理设置 HTTP缓存

  http协议是无状态的应用层协议,意味着每次http请求都须要创建通讯链路、进行数据传输,而在服务器端,每一个http都须要启动独立的线程去处理。web

这些通讯和服务的开销都很昂贵,减小http请求的数目可有效提升访问性能。浏览器

  减小http的主要手段是合并CSS、合并javascript、合并图片。将浏览器一次访问须要的javascript和CSS合并成一个文件,这样浏览器就只须要缓存

次请求。图片也能够合并,多张图片合并成一张,若是每张图片都有不一样的超连接,可经过CSS偏移响应鼠标点击操做,构造不一样的URL。浏览器请求数据会性能优化

优先考虑缓存,若是缓存里有且没有过时就会从缓存里取。缓存的力量是强大的,恰当的缓存设置能够大大的减小 HTTP请求。服务器

二、利用多个域名来存储网站资源

  1. 能够节约cookie带宽。 

  一方面,cookie包含在每次请求和响应中,太大的cookie会严重影响数据传输,所以哪些数据须要写入cookie须要慎重考虑,尽可能减小cookie中传输

的数据量。另外一方面,对于某些静态资源的访问,如CSS、script等,发送cookie没有意义,能够考虑静态资源使用独立域名访问,避免请求静态资源时发

送cookie,减小cookie传输次数。

  2. 节约主域名的链接数,优化页面响应速度。

突破浏览器并发限制(浏览器的并发请求数目限制是针对同一域名的,超过限制数目的请求会被阻塞)你随便挑一个 G家的 url: https://lh4.googleu

sercontent.com/- si4dh2myPWk/T81YkSi__AI/AAAAAAAAQ5o/LlwbBRpp58Q/w497-h373/IMG_20120603_163233.jpg, 把前面的 lh4换成

lh3,lh6 啥的,都照样可以访问,像地图之类的须要大量并发下载图片的站点,这个很是重要。

三、编辑html的时候注意语义结构化

  结构语义化:根据内容的结构,选择合适的标签,以便于开发者阅读和写出更优雅的代码,同时让浏览器的爬虫和机器很好地解析。

  结构语义化的优势包括:

    1. 在页面没有css或者css还未加载出来的时候,页面也能呈现出很好的结构。

    2. 有利于SEO,易于被搜索引擎抓取,有利于推广。

    3. 方便盲人阅读器、屏幕阅读器等等设备来解析。

    4. 用户体验更好,例如图片的alt属性,在图片没有加载出来时给予合理的解释。

    5. 便于团队开发和维护。

    6. 遵循分离结构和表现原则。

四、启用压缩

  在服务器端对文件进行压缩,在浏览器端对文件解压缩,可有效减小通讯传输的数据量。若是能够的话,尽量的将外部的脚本、样式进行合并,多个合

为一个。文本文件的压缩效率可达到80%以上,所以HTML、CSS、javascript文件启用GZip压缩可达到较好的效果。可是压缩对服务器和浏览器产生必定

的压力,在通讯带宽良好,而服务器资源不足的状况下要权衡考虑。

五、CSS放在页面最上部,javascript放在页面最下面

  浏览器会在下载完成所有CSS以后才对整个页面进行渲染,所以最好的作法是将CSS放在页面最上面,让浏览器尽快下载CSS。若是将 CSS放在其余地方

好比 BODY中,则浏览器有可能还未下载和解析到 CSS就已经开始渲染页面了,这就致使页面由无 CSS状态跳转到 CSS状态,用户体验比较糟糕,因此能够

考虑将CSS放在HEAD中。

  Javascript则相反,浏览器在加载javascript后当即执行,有可能会阻塞整个页面,形成页面显示缓慢,所以javascript最好放在页面最下面。但若是页面

解析时就须要用到javascript,这时放到底部就不合适了。

相关文章
相关标签/搜索