サイトのパフォーマンスを上げる、PHPでCSSファイルを圧縮転送する各種方法
2008年12月25日-
3 ways to compress CSS files using PHP
サイトのパフォーマンスを上げる、PHPでCSSファイルを圧縮転送する各種方法
1. ob_start で gzhandler を使う方法
<?php if(extension_loaded('zlib')){ob_start('ob_gzhandler');} header("Content-type: text/css"); ?>
body{ background-color:#000000; }
<?php if(extension_loaded('zlib')){ob_end_flush();}?>
gzip圧縮なので、無理にphpにする必要もないですが、まず基本の方法。でもまだ不十分ですね。
2. 1の方法に、Expiresヘッダーを追加してローカルにキャッシュさせる方法
<?php
ob_start ("ob_gzhandler");
header ("content-type: text/css; charset: UTF-8");
header ("cache-control: must-revalidate");
$offset = 60 * 60 * 24 * 30; // 30 日間
$expire = "expires: " . gmdate ("D, d M Y H:i:s", time() + $offset) . " GMT";
header ($expire);
$css = "body{ background-color:red }";
echo $css;
ob_end_flush();
?>
Expiresをつければ、その間のサーバへのCSSアクセスを減らすことができ、パフォーマンスはかなりあがります
ブラウザでの表示も高速化しますね
注意として、期間を長くしすぎると、Expiresが利きすぎてCSSが更新されないということ。
HTMLからCSSを呼び出す際のCSSファイル名を変える必要があります。
3. 複数のCSSファイルを1つにまとめて改行、スペースを取り除いて出力
<?php
header('Content-type: text/css');
ob_start("compress");
function compress($buffer) {
/* remove comments */
$buffer = preg_replace('!/*[^*]**+([^/][^*]**+)*/!', '', $buffer);
/* remove tabs, spaces, newlines, etc. */
$buffer = str_replace(array("rn", "r", "n", "t", ' ', ' ', ' '), '', $buffer);
return $buffer;
}
/* your css files */
include('master.css');
include('typography.css');
include('grid.css');
include('print.css');
include('handheld.css');
ob_end_flush();
?>
2と3を組み合わせて、圧縮&連結しつつExpiresヘッダーを出すようなものがよいかもしれませんね。
さらには、includeするCSSを引数で指定できるようにすれば、なかなかよさそうです。
関連エントリ
最新のブログ記事(新着順)
- 15000以上のいい感じの線形アイコン「Lineicons」
- CSSやTailwindでのCSSスニペットライブラリ「CSS Snippets Library」
- AIを使ってサイトマップが作れる「Octopus.do」
- ライブラリ依存のないモーダルオープンライブラリ「Blendy」
- 個性的な明朝フリーフォント「築豊初号明朝OFL」
- CSSで太陽が差し込むようなアニメーション実装
- 可愛くアニメーションする「beautifully crafted animated icons」
- アイソメトリックなアイコンがアイコンがPNG,SVGでゲットできる「Isoicons」
- ユニークなカタカナフォントtorisippo
- 美しいメッシュグラデーションをCSSで簡単に取得できる「MSHR」
- 過去のエントリ