Categories
CSS Sass

Sassで”不要なCSS”を出力しない – nullの使い方

最近は通信速度も向上して、CSSの大容量化による WEB ページ表示速度の低下も問題視されなくなってきたと思います。実際に、CSS をスリム化する程度で本格的に構造自体を毎案件ごと手を付ける方も少なくなったのではないでしょうか。 WordPress を使用している方は最適化されたサーバーというものも存在しています。ここであえて、ms (ミリセック) を狩る狩人方には Sass をお勧めしたいと思います。

 

不要なベンダープレフィックスを表示しない

この内容は、「Sassで使用するベンダープレフィックスだけを出力する – @ifを使う」にて紹介しています。処理の構造自体は、 @if と、 @each 、リスト変数を利用したものです。一つのプロパティに対して不要な記述を減らす場合は、この機能を流用すれば可能となります。汎用性は高いかと思いますので是非参考にしてみてください。

プロパティを表示しない

以下のソースを見てください。

@mixin mixinTest($value: null) {
    div.testclass {
        height: 200px;
        width: $value;
    }
}

@include mixinTest();

$value に null を指定しています。この null が今回の記事でのポイントとなります。出力結果である CSS は以下となります。

div.testclass {
  height: 200px; }

width が出力されていません。これは null を指定したためプロパティが生成されなかったためです。この機能を使えば、不要なプロパティ自体を記述させないようにすることができます。

クラス(セレクタ)を表示しない

もう一つ null には重要な機能があります。以下のソースを見てください。

@mixin mixinTest($value: null) {
    div.testclass1 {
        width: 500px;
    }

    div.testclass2 {
        width: $value;
    }
}

@include mixinTest();

上記コードの出力結果です。

div.testclass1 {
  height: 200px; }

testclass2がありませんね。これは書き間違いではありません。全てのプロパティが null であった場合は中身が存在しないため class (セレクタ)自体生成されないのです。例えば、以下のようなこともできます。

$value: null !default;
@mixin mixinTest() {
    div.testclass {
        @content;

        width: $value;
        $value: null;
    }
}


@include mixinTest(); // 生成されない
@include mixinTest { $value: 999px; }
@include mixinTest(); // 生成されない
@include mixinTest { $value: 111px; }

そして出力されるコードは以下となります。

div.testclass {
  width: 999px; }

div.testclass {
  width: 111px; }

testclass が2つ出力されているのは気にしないでください。注目して欲しいところは、 @content で展開するコード内に、 $value を定義していなければ testclass が生成されないことです。

 

@content を使わずとも同様の処理を作ることはできますが、どうせなので @content を使ってみました。 @content については「Sassの@contentの使い道とは? – @contentの実験と結果」にて紹介しています。

 

不要な CSS を出力しないように Sass の記述に気を配ることで、自動でほぼ最適な CSS を吐き出すようにすることができます。毎プロジェクトごとに CSS を追っかける必要はありません。是非参考にしてみてください。

12 replies on “Sassで”不要なCSS”を出力しない – nullの使い方”

legend blue 11s…

jordan 4 columbia swfbyt legend blue 11s pantone 11s hvadln jordan 7 french blue pbzgrbk legend blue 11s legend blue 11s metudtllhla legend blue 11s kfoeuecxd french blue 7s [url=http://www.forestlodgedonegal.com/jordan11pantoneblue/]jordan 11 pantone …

jordan 11 legend blue…

njfjecwt Jordan 10 Lady Liberty Lady Liberty 10s gnqlaj prbiugnxk rnotstk Bulls Over Broadway 10s [url=http://www.iseco.biz/jordan11legendblue/index.html]jordan 11 legend blue[/url] pvrcvf Jordan 10 Lady Liberty [url=http://www.istools.it/Jordan10Bulls…

jordan 11 legend blue…

[url=http://www.milupa.it/Jordan10BullsOverBroadway/index.html]Jordan 10 Bulls Over Broadway[/url] Lady Liberty 10s inmlptkd Jordan 10 Bulls Over Broadway [url=http://www.entracque.org/BullsOverBroadway10s/index.html]Bulls Over Broadway 10s[/url] jorda…

jordan 4 oreo…

A 6 foot 6 forward, he was known as a tough defender and rebounder. If a rider passes the ball and the guy catching the ball steps off his board that is also a turnover. Jammed fingers, sprained ankles, and broken limbs are common occurences for Injury…

buy jorans…

Iron is most available to the body when chelated to amino acids iron in this form is ten to fifteen times more bioavailable[8] than any other, and is also available for use as a common iron supplement. As a matter of fact, we had a parochial all girls …

Jordan 10 Lady Liberty…

Jordan 10 Lady Liberty [url=http://www.iseco.biz/jordan11legendblue/index.html]jordan 11 legend blue[/url] jordan 7 french blue Jordan 10 Bulls Over Broadway jordan 11 legend blue [url=http://www.lydiasimon.com/BullsOverBroadway10s/index.html]Bulls Ove…

french blue 7s…

More frustrating, however, according to Ms Backhouse, is the fact that Coffs Harbour City Council has completely wiped its hands of the matter.surge was caused by a council contractor mulching green waste on council MacCues Rd reserve on Good Friday, M…

jordan 7 french blue…

Man, he had cake on every inch of his face. The best backboards will cost more money, and frankly they’re well worth it.. The food is excellent and the dress is dressy/casual. Under Armour raised its full year guidance during the second quarter call, …

oreo 4s…

Marami kang makikilala, matututunan, tapos para ka pang role model na makikilala ng mga tao. Every morning to sign up conditioning drills inside of an hour. If you are new to finding a basketball knee support, you might have noticed that there are a to…

legend blue 11s…

jordan 11 legend blue jordan 11 legend blue [url=http://www.iseco.biz/Jordan10BullsOverBroadway/index.html]Jordan 10 Bulls Over Broadway[/url] lpautmk [url=http://www.comune.caprauna.cn.it/Jordan10BullsOverBroadway/index.html]Jordan 10 Bulls Over Broad…

buy jorans…

french blue 7s [url=http://www.emeraldwave.co.uk/jordan7frenchblue/]jordan 7 french blue[/url] [url=http://www.conceptboats.com/userfiles/jordan7frenchblue/]jordan 7 french blue[/url] jordan 7 french blue jordan 7 french blue french blue 7s [url=http:/…

Jordan 10 Bulls Over Broadway…

Jordan 10 Bulls Over Broadway [url=http://baf.safmarine.com/frenchblue7s/]frenchblue 7s[/url] buy jordans [url=http://baf.safmarine.com/frenchblue7s/]frenchblue 7s[/url] hoinimkv [url=http://www.rosanerogirls.it/public/BullsOverBroadway10s/]Bulls Over …

Leave a Reply

Your email address will not be published. Required fields are marked *