サイトのパフォーマンスを上げる、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を引数で指定できるようにすれば、なかなかよさそうです。
関連エントリ
最新のブログ記事(新着順)
- 小説表紙などに使えそうな商用可なフォント「になロマン」
- 筆で書いたようなカナ書体「筆竹仮名B」
- 無料・商用利用可な丸文字ピクセルフォント「マルミーニャM」
- スペースコブラ風フォント
- Next.jsのVercelから商用利用可能なフリー汎用フォント「Geist Font 」
- 無料で使えるいい感じの日本語フォント「しっぽり太ゴシック」
- CSSのみで実装された500種類のローディングアニメーション「CSS Loaders」
- 画像ホバーで様々なエフェクトをかけられる「Izmir」
- CSSのbox-shadowをGUIで生成できる「CSS Box Shadows Generator」
- 好きな画像や文字を埋め込んだQRコードをリアルタイムで作れるWEBツール
- 過去のエントリ