时间:2021-07-01 10:21:17 帮助过:13人阅读
首先说说对CSS和JS文件进行性能优化的几个小技巧:
在存放CSS的文件夹中新建一个style.php文件,在此文件中加入以下代码:
输出buffer中的内容,即压缩后的css文件if(extension_loaded('zlib')){//检查服务器是否开启了zlib拓展
ob_start('ob_gzhandler');
}
header('content-type: text/css; charset: utf-8');//注意修改到你的编码
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();//
?>
如果你处理的是JavaScript文件,你需要将上面代码中的第5行的Content-type修改成以下:
header('content-type:application/x-javascript; charset: utf-8');
修改完成之后,引入相关需要的CSS文件,然后再原HTML引入CSS的地方相应的替换为如下的引入方式:
同理JS引入方式如下:
由于上面代码中使用到了HTTP的Expires(过期)属性用于在客户端缓存CSS/JS代码,所以,如果过期时间设置的太长(比如一 年),当你在服务器端修改了JS/CSS代码时,客户端可能不会立即生效。
解决办法是:在php文件后面添加一个随机参数,如上面例子中的v=121,当下次修改了文件时,记得相应修改此随机参数(比如修改为122)即可。