CSSファイル数を減らしてページ表示時間を最適化
公開日 更新日 2014/11/22
STINGERテンプレートの場合、ダウンロード対象のCSSファイルは2つあります。
少しでも表示時間を短くするためにはダウンロード対象のファイル数を減らすと効果的だと言われてます。
そこで、まずは複数あるCSSファイルのダウンロードを最適化するという目的で、SASSを導入してみました。
Contents
STINGERが使うCSS
STINGERテンプレートの中で使っているCSS定義は、以下の2つのファイルに分割されて保存されています。
- style.css
WordPressで予約されたファイルであって、テーマ作成時の必須ファイルです。
STINGERとしてのテーマ本体という位置づけになっているようです。 - css/normalize.css
STINGERとしてのカスタマイズに先立って複数ブラウザの挙動を初期化するために読み込んでいるファイルです。
先頭行にコメント記載があり、normalizeを同梱しているようです。
1 |
/*! normalize.css v3.0.1 | MIT License | git.io/normalize */ |
この記事では、STINGER使用時にダウンロードされる2つのCSSファイルを1つにまとめておき、表示時間を短くすることを考えてみました。
SASSの導入
この記事ではSASSについて既に導入済みであることが前提ですが、環境構築はこちらの記事にまとめましたので良かったらこちらも見てください。
また、SASSに関する書籍もあります。
CSSからSASSに変換
今回2つあるCSSファイルをどちらかに集約することを考えますが、前述のとおりでstyle.cssファイルはWordPressにおける必須ファイルという位置づけなので、normalize.cssのダウンロード箇所を削除してstyle.cssへ集約します。
準備としてSASS用のファイルを作成するために、以下のSASS提供コマンドでstyle.cssとnormalize.cssについて、scss版を作成します。
1 2 |
sass-convert --from css --to scss style.css style.scss sass-convert --from css --to scss css\normalize.css css\_normalize.scss |
これでSASS形式への変換が完了となりますが、今後はSASSファイルのほうでメンテナンスするので、特にstyle.scssについては全体を見ておいたほうが良い気がします。
むしろ自動変換じゃなくて、手作業で変換したほうが衛生的かもしれません…。
SASSでファイル統合する定義に変更
SASSの場合、「@import」命令を使うことで複数あるCSSファイルの統合が出来ます。
今回はこの機能を導入してCSSファイルを1つにまとめたいと思いますが、そのためのソース修正を以下にまとめます。
style.scss
normalize.cssはスタイルをリセットするのが役目なので、style.scssの定義が始まる前に真っ先にnormalize.scssをインポートしてしまいます。
1 2 3 4 5 |
/*-------------------------------- //★追加 Import css/_normalize.scss //★追加 ---------------------------------*/ //★追加 @import "css/normalize.scss"; //★追加 /*-- ここまで --*/ //★追加 |
header.php
STINGERはもともとこのファイルでstyle.cssの読み込みの前にnormalize.cssを読んでいる作りでしたが、不要になったので1行削除します。
以下抜粋で言う5行目のget_stylesheet_uri()がstyle.cssへのパスへ変換されることになります。
1 2 3 4 5 |
</title> <!-- ★削除 <link rel="stylesheet" href="<?php bloginfo('template_directory'); ?>/css/normalize.css"> --> <link rel="stylesheet" href="<?php echo get_stylesheet_uri(); ?>" type="text/css" media="screen" /> |
SCSSからCSSへコンパイル
style.scssにてnormalize.scssをインポートする定義を追加して、SCSSの準備が出来たので、以下のようにしてstyle.scssファイルからstyle.cssファイルを作成します。
1 |
sass style.scss > style.css |
これでstyle.cssが出力されますが、先頭のコメントはWordPressの必須の定義なので、壊れていないことをチェック。
無事cssファイルへ出力できたら完成です。
余談ですがライセンスについて
STINGERはGPLライセンス。
1 2 3 4 5 6 7 8 9 10 11 |
/*--------------------------------------------------------- Theme Name: stinger5ver20141011 Theme URI: http://wp-fun.com Description: stinger5 Author: enji Author URI: http://wp-fun.com License: GNU General Public License v2 or later License URI: http://www.gnu.org/licenses/gpl-2.0.html Tags: flexible-width, custom-header, custom-menu, editor-style, Version: 20141011 ---------------------------------------------------------*/ |
それに対してnormalize.cssはMITライセンス。
SASSコマンドで作成したstyle.scss,normalize.scssは元々のライセンスを継承します。
そして気になるのは、scssファイルからコンパイルして得られるstyle.cssがどうなるか?
WEB検索するとこちらのページにまとめ記事あり。
GPLやMITやCCなど主要ライセンスの内容と意味のまとめ
GPL(GNU General Public License)
「GPLライセンスのソフトウェアやプログラムを使用した場合、その制作物もGPLライセンスで配布しなければならない」という、歪みねぇ制約。MIT License(X11 License、X Licenseとも呼ばれる)
「修正済みBSDライセンス」と同条件のライセンスになります。BSD(Berkeley Software Distribution License)
1つ目は「再配布時には著作権表示を残す」という事。
もうひとつはGPLライセンスでも明示されていた「無保証である」という事。
この2点を守りさえすれば、どのように利用しても構いません。
ライセンスをGPLに変えて再配布するもよし、改変して独占販売するもよし、ソフトウェアだけ頒布してソースを非公開にしてもよし。
解釈上、MIT(≒BSD)の場合はMITというライセンスの変更が禁止されていないのでGPLへの変更が可能。
対して、GPLではライセンスの変更はしてはいけないため、制作物はGPLを継承しないといけない。
ということでまとめると、SASSコンパイルによって出力されるstyle.cssは、以下2つのファイルを入力としてます。
そのためGPLライセンスが生き残り、結果SASSコンパイルによって出力されるstyle.cssはGPL扱いとなるようです。
- MITライセンスのnormalize.css
- GPLライセンスのSTINGERで提供されるstyle.css
この修正による感触
正直、高々2ファイルが1ファイルになるというだけといえるので、あまり実感が無いです…。
体感的にも違いはなさそう。
とは言え、この修正からはSTINGERのスタイルをSASSでの管理に切り替えることが出来ており、収穫はあったのかなと思ってます。
レスポンシブ広告
関連記事
-
記事一覧に表示する各記事の抜粋を綺麗に整形表示する
STINGERのホーム画面や月まとめ等のアーカイブ系のページに表示される記事一覧 …
-
記事の幅を広げるカスタマイズ(V3用)
STINGERをインストールした状態だと、記事の幅が550pxになっています。 …
-
スクロールしても記事タイトルをずっと画面に固定表示するカスタマイズ(V3用)
WordPressのSTINGERテンプレートに対して、記事タイト …
-
広告フロートの動きがおかしい問題の回避方法
WordPressテーマSTINGERの サイドバーにある「スクロール広告用」は …
-
WordPressテーマをSTINGER5にバージョンアップ
STINGER配布サイトにて、STINGERのV5メジャーアップのアナウンスを発 …
-
パンくずリストの最後の”>”を削除するカスタマイズ
STINGERテンプレートだと、パンくずリスト(ブレッドクラム / トピックパス …
-
記事の幅を広げるカスタマイズ(V5用)
以前STINGER v3にて、こちらの記事(記事の幅を広げるカスタマイズ)で記事 …
-
スクロールしても記事タイトルをずっと画面に固定表示するカスタマイズ(V5用)
はじめに STINGER V3からV5にバージョンアップしたのが2014/9/ …
-
パンくずリストをもっとカッコよくする
STINGERテンプレートは、WordPressサイトのテーマとし …
-
記事一覧に表示する各記事の概要を「続きを読む」タグまでにする
Information この記事はSTINGER v3用のカスタマイズ方法です。 …
- PREV
- ログインページの表示を自分だけ許可することでセキュリティ確保
- NEXT
- ソラリス