减少HTTP请求来加快页面响应速度的三种做法,CSS Sprites|内联图片|合并脚本和CSS

简介: 减少HTTP请求来加快页面响应速度的三种做法,CSS Sprites|内联图片|合并脚本和CSS

Web页面的响应速度对一个网站至关重要,响应得快,用户的反馈肯定是好评;响应的慢,用户会敬而言之。性能黄金法则告诉我,用户响应时间的80%-90%花费在为页面加载脚本、样式表,以及图片。那么如果能够在这三个方面做出调整,那么页面响应速度就能够得到大幅度的提高。


1)CSS sprites


在我最初的认知里,我以为CSS sprites就是图片地图,但其实并不是这样。图片地图主要应用于在一张图片上链接多个URL。CSS sprites和图片地图有相似之处,那就是都需要把多个图片合并成一张。


来看这样一张导航效果图,如图1。

image.png



它的背景图片是这样的,如图2。

image.png



该怎么实现这样的效果呢?


来看页面导航条的HTML元素构成:


<ul>

<li class="nav_1"></li>

<li class="nav_2"></li>

<li class="nav_3"></li>

<li class="nav_4"></li>

<li class="nav_5"></li>

</ul>


首先,需要为五个<li>标签指定 background-image,代码如下:


ul li {

   background-image: url(../ec_good_index.png);

   background-repeat: no-repeat;

   display: block;

   background-size: 63px 378px;

   width: 63px;

   height: 63px;

}


background-size很重要,因为图2中的图片实际大小是150*900,比我们想要的背景图要大,如果不设置background-size,那么就无法取到想要的图片导航。


接着,我们为每个li标签指定background-position,它是CSS sprites的核心,通过background-position,可以将li标签放到背景图期望的位置上,代码如下:


ul li.nav_1 {
    background-position: 0 0;
}
ul li.nav_2 {
    background-position: 0 -63px;
}
ul li.nav_3 {
    background-position: 0 -126px;
}
ul li.nav_4 {
    background-position: 0 -189px;
}


图片在y轴的向下的方向上递增,也就是说背景图上的第一个位置为0,0,那么第二个位置就是0,-63,也就是说第二张导航图在第一张的下方,偏移63像素,也就是第二章导航图的高度。第三张为-126,依次类推。


如果背景图上的图标是横向排列的,position坐标就有所不同,你可以实践一下。


CSS sprites是一种优秀的解决方案——更少的图片,更短的响应时间——对导航栏、链接等提供大量图片有很大的改善。在上例中,使用一张背景图,比使用5个背景图显然要少4次HTTP请求,很明显就可以缩短响应时间。


2)内联图片


通过使用data:URL模式可以在页面中展示图片还无需任何额外的HTTP请求,它的主要用例就是lazyload 的解决方案。在lazyload 中,图片在初始化时就使用的是data:URL的模式,请看的初始化参数,代码清单1。


$.fn.lazyload = function(options) {
        var elements = this;
        var $container;
        var settings = {
            event           : "scroll",
            effect          : "show",
            data_attribute  : "original",
            placeholder     : "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB/AAffA0nNPuCLAAAAAElFTkSuQmCC"
        };
    if ($self.is("img")) {
      $self.attr("src", settings.placeholder);
    }
})(jQuery, window, document);

lazyload 在初始加载时的请求,截图如下,可以看得出,并没有发送HTTP请求。




data:URL的好处就是数据就在其URL自身当中,一个image可以通过<img src="data:image/png;base64,base64字符串"/>的方式进行表示——但,请尽量不要在表示大图片时使用它,因为base64编码后的内容也会比较大。


另外,比较遗憾的是,在我写这篇博客时,没有找到方法来通过Java代码把一个图片文件转成base64的字符串。


3)合并脚本和css


在我的传统观念里,代码一定要模块化,也就是说最好脚本、css要分开,通过不同的文件来减少代码之间的影响。但合并脚本和css后,网站的响应速度的确是有了大幅度的提升——我被迫接受把本和样式表合并在一起的观念,这很痛苦。


但经过尝试后,我发现,把很多脚本合并在一个脚本也能很好的保持代码的模块化,经过反复的调整,最终形成了自己并不完善的规范,但自我感觉还不错。


$(function() {
    YUNM.init("/components/common/ec.frag.xml", {
        debug : true, // 调试模式 【true|false】
        callback : function() {
            // 初始化页面中的组件
            initEnv();
            doBody();
            // 共同的顶级的
            doSome();
            doSwiper();
            quickNavigation();
            // 放在最后,安卓的微信、在移动网络下会阻塞
            // 微信朋友圈分享、发送给朋友、主动扫描二维码
            // TODO 如果有主动分享的需求,减少签名的请求
            weixinShare();
        }
    });
});

对于css来说,关键的就是在写css时,一定要从dom书的顶级到子集一层层扩展。


.weui-cells_form .weui-cell__ft {

   font-size: 12px

}


好了,到此为此,三种做法是点到了,但文章写得很散漫。希望自己在接下来有时间的话,重新来整理这篇文章,为读者展示一个更好的阅读体验。


相关文章
|
16天前
|
监控 网络协议 应用服务中间件
【Tomcat源码分析】从零开始理解 HTTP 请求处理 (第一篇)
本文详细解析了Tomcat架构中复杂的`Connector`组件。作为客户端与服务器间沟通的桥梁,`Connector`负责接收请求、封装为`Request`和`Response`对象,并传递给`Container`处理。文章通过四个关键问题逐步剖析了`Connector`的工作原理,并深入探讨了其构造方法、`init()`与`start()`方法。通过分析`ProtocolHandler`、`Endpoint`等核心组件,揭示了`Connector`初始化及启动的全过程。本文适合希望深入了解Tomcat内部机制的读者。欢迎关注并点赞,持续更新中。如有问题,可搜索【码上遇见你】交流。
【Tomcat源码分析】从零开始理解 HTTP 请求处理 (第一篇)
|
5天前
|
JSON Java 数据格式
java操作http请求针对不同提交方式(application/json和application/x-www-form-urlencoded)
java操作http请求针对不同提交方式(application/json和application/x-www-form-urlencoded)
10 1
|
25天前
|
JSON JavaScript 前端开发
Haskell中的数据交换:通过http-conduit发送JSON请求
Haskell中的数据交换:通过http-conduit发送JSON请求
|
25天前
|
开发者
HTTP状态码是由网页服务器返回的三位数字响应代码,用于表示请求的处理结果和状态
HTTP状态码是由网页服务器返回的三位数字响应代码,用于表示请求的处理结果和状态
24 1
|
Web App开发 前端开发 Java
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html><head><meta http-equiv="Cont
线程的状态有:new、runnable、running、waiting、timed_waiting、blocked、dead 当执行new Thread(Runnabler)后,新创建出来的线程处于new状态,这种线程不可能执行 当执行thread.start()后,线程处于runnable状态,这种情况下只要得到CPU,就可以开始执行了。
720 0
|
Web App开发 前端开发
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html><head><meta http-equiv="Cont
Found lingering reference异常 ERROR: Found lingering reference file hdfs://jiujiang1:9000/hbase/month_hotstatic/...
712 0
|
Web App开发 前端开发 Java
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html><head><meta http-equiv="Cont
java链接MongoDB处理大量数据时经常碰到cursor not found 的异常,其实是超时所致 Exception in thread "main" com.
824 0
|
Web App开发 Linux
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html><head><meta http-equiv="Cont
内存是影响Linux性能的主要因素之一,内存资源的充足与否直接影响应用系统的使用性能。 free命令:监控Linux内存使用状况。
1155 0
|
Web App开发 监控 前端开发
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html><head><meta http-equiv="Cont
负载均衡: LVS(Layer 4), HAProxy(Layer 4、 7),Nginx(Layer 7) 虚拟化: LXC、KVM、Xen HA:Keepalived、Heartbeat 分布式缓存...
752 0
|
Web App开发 监控 前端开发
下一篇
无影云桌面