zoukankan      html  css  js  c++  java
  • web 新能优化

    网上的东西太多了都是搜来的东西 留着自己看吧!

    摘自 :http://www.cnblogs.com/50614090/archive/2011/08/19/2145620.html 

     打开网站慢现状分析

    在公司访问部署在IDC机房的VIP网站时会感觉很慢。是什么原因造成的?为了缩短页面的响应时间,改进我们的用户体验,我们需要知道用户的时间花在等待什么东西上。

           可以跟踪一下我们的登录页面,如下图所示

        从上图我们可以分析知道,HTML文档只占了总响应时间的20%,其它80%响应时间用来下载JS、CSS、图片等组件。所以WEB前端有很大的优化空间,我们将从WEB的前端优化、后端优化两方面综合考虑给出WEB的性能优化方案。

     WEB前台的优化规则

    一、尽量减少 HTTP 请求

    有几种常见的方法能切实减少 HTTP 请求:

    1、 合并脚本跟样式文件,如可以把多个 CSS 文件合成一个,把多个 JS 文件合成一个。

    2、 CSS Sprites 利用 CSS background 相关元素进行背景图绝对定位,把多个图片合成一个图片。

    二、使用浏览器缓存

           在用户浏览网站的不同页面时,很多内容是重复的,比如相同的JS、CSS、图片等。如果我们能够建议甚至强制浏览器在本地缓存这些文件,将大大降低页面产生的流量,从而降低页面载入时间。

       根据服务器端的响应header,一个文件对浏览器而言,有几级不同的缓存状态。

       1、服务器端告诉浏览器不要缓存此文件,每次都到服务器上更新文件。

       2、服务器端没有给浏览器任何指示。

       3、在上次传输中,服务器给浏览器发送了Last-Modified或Etag数据,再次浏览时浏览器将提交这些数据到服务器,验证本地版本是否最新的,如果为最新的则服务器返回304代码,告诉浏览器直接使用本地版本,否则下载新版本。一般来说,有且只有静态文件,服务器端才会给出这些数据。

       4、服务器强制要求浏览器缓存文件,并设置了过期时间。在缓存未到期之前,浏览器将直接使用本地缓存文件,不会与服务器端产生任何通信。

           我们要做的是尽量强制浏览器到第四种状态,特别是对于JS、CSS、图片等变动较少的文件。

    三、使用压缩组件

    IE和Firefox浏览器都支持客户端GZIP,传输之前,先使用GZIP压缩再传输给客户端,客户端接收之后由浏览器解压,这样虽然稍微占用了一些服务器和客户端的CPU,但是换来的是更高的带宽利用率。对于纯文本来讲,压缩率是相当可观的。如果每个用户节约50%的带宽,那么租用来的那点带宽就可以服务多一倍的客户,并且缩短了数据的传输时间。

    四、图片、JS的预载入

    预载入图像最简单的方法是在 JavaScript 中实例化一个新 Image() 对象,然后将需要载入的图像的 URL 作为参数传入。

    function preLoadImg(url) {

    var img = new Image();

    img.src = url;

    }

    可以在登录页面预载入JS和图片

    五、将脚本放在底部

    脚本放在顶部带来的问题,

    1、  使用脚本时,对于位于脚本以下的内容,逐步呈现将被阻塞

    2、  在下载脚本时会阻塞并行下载放在底部可能会出现JS错误问题,当脚本没加载进来,用户就触发脚本事件。

    要综合考虑情况。

    六、将样式文件放在页面顶部

    如果样式表任在加载,构建呈现树就是一种浪费,样式文件放在页面底部可能会出现两种情况:

    1、  白屏

    2、  无样式内容的闪烁

    七、使用外部的JS和CSS将内联的JS和CSS做成外部的JS、CSS。减少重复下载内联的JS和CSS。

    八、切分组件到多个域主要的目的是提高页面组件并行下载能力。但不要跨太多域名,建议采用2个子域名。

    九、精简JS

    可以做到两个级别

    1、精简:从代码中移除不必要的字符以减少其大小,

    2、混淆:在精简的同时,还会改写代码,函数、变量名被转换成更短的字符串

    可以使用ShrinkSafe来精简JS  http://shrinksafe.dojotoolkit.org/

    十、精简CSS

    从代码中移除不必要的字符以减少其大小,

    可以使用CSS Compressor http://www.cssdrive.com/index.php/main/csscompressor /

    十一、       精简图片、Flash

    对大图片、Flash,要在效果和大小之间做出平衡。

  • 相关阅读:
    简易发号SQL,可用于生成指定前缀自增序列--改进版
    关于【【故障公告】数据库服务器 CPU 近 100% 引发的故障(源于 .NET Core 3.0 的一个 bug)】IS NOT NULL测试
    简易发号SQL,可用于生成指定前缀自增序列,如订单号,生成优惠券码等
    [EntityFramework]记录Linq中如何比较数据库中Timestamp列的方法(如大于0x00000000000007D1的记录)
    [高并发]抢红包设计(使用redis)
    [.Net跨平台]部署DTCMS到Jexus遇到的问题及解决思路--验证码
    [.Net跨平台]部署DTCMS到Jexus遇到的问题及解决思路---部署
    【迷你微信】基于MINA、Hibernate、Spring、Protobuf的即时聊天系统 :1.技术简介之Mina连接
    Unity光晕剑效果的Shader简单实现
    Unity3D 调用Android与IOS的剪贴板
  • 原文地址:https://www.cnblogs.com/daipenglin/p/4798838.html
Copyright © 2011-2022 走看看