网站分类
文章归档
统计信息
  • 文章总数:103
  • 页面总数:2
  • 分类总数:10
  • 标签总数:521
  • 评论总数:0
  • 浏览总数:149433
  • 网站运行:3394天
相关文章
标签列表
RSS

用PHP压缩网站JS/CSS文件

首先说说对css和js文件进行性能优化的几个小技巧:

将多个CSS/JS文档合并成一个文件,以减少HTTP请求

对合并后的文件进行文档压缩,比如分别使用js compressor和CSS compress

如果使用到一些主流的JavaScript框架,比如JQuery, Mootools或者YUI,强烈推荐直接使用Google AJAX Library以外部链接的形式导入基库。

最后,就是本文所提到的,使用GZIP在服务器端对JS/CSS文档进行压缩。

这里提到的方法对系统来说是无侵入式的,也就是说不管你的程序是新编写的,还是已经上线了很久,均适用。

实际上,用PHP使用GZIP压缩非常简单,其核心是使用ob_gzhandler,不过需要注意的一点是,并不是所有浏览器都支持GZIP传送到客户端的数据,所以要进行一定的容错处理。

下面是使用PHP通过GZIP压缩CSS的实例。

在存放CSS的文件夹中新建一个style.php文件,在此文件中加入以下代码:


<?php
if(extension_loaded(‘zlib’))
{
//检查服务器是否开启了zlib拓展 ob_start(‘ob_gzhandler’);
}
header (“content-type: text/css; charset: gb2312”);
//注意修改到你的编码
header (“cache-control: must-revalidate”); $offset = 60 * 60 * 24;
//css文件的距离现在的过期时间,这里设置为一天
$expire = “expires: ” . gmdate (“D, d M Y H:i:s”, time() + $offset) . ” GMT”; header ($expire); ob_start(“compress”);
function compress($buffer) {
//去除文件中的注释
$buffer = preg_replace(‘!/\*[^*]*\*+([^/][^*]*\*+)*/!’, ”, $buffer); return $buffer;
}
//包含你的全部css文档
include(‘global.css’); include(‘layout.css’); if(extension_loaded(‘zlib’)){ ob_end_flush();
//输出buffer中的内容,即压缩后的css文件
}
?>


如果你处理的是JavaScript文件,你需要将上面代码中的第5行的Content-type修改成以下:

header (“content-type:application/x-javascript; charset: gb2312”);

同样需要注意的是文件的编码,这里我用的是gb2312,如果你采用的是UTF-8或其他编码,修改成对应的即可。

修改完成之后,在原引入CSS和JS文件的地方,将.css后缀/.js后缀的文件更换成这个style.php文件即可,如:

script type=”text/javascript” src=”http://XXXXXX/autoSuggest.js.php?v=121

由于上面代码中使用到了HTTP的Expires(过期)属性用于在客户端缓存CSS/JS代码,所以,如果过期时间设置的太长(比如2020 年),当你在服务器端修改了JS/CSS代码时,客户端可能不会立即生效。解决办法是:在php文件后面添加一个随机参数,如上面例子中的v=121,当 下次修改了文件时,记得相应修改此随机参数即可。

分类:网站建设 已阅:995
关键字:css  js  php  压缩  缓存CSS  网站  
上一篇:免费虚拟主机host-ed.me
下一篇:.htaccess实现PHP伪静态
Copyright © 2014-2015 点点看看 保留所有权利 豫ICP备19041083号-1 公安部备案号41010202002818