CSS

CS-Cartで利用されているCSS関連技術の概要

LESS

600

CS-CartのレイアウトスタイルはLESSを用いて書かれています。
LESSは、非常に便利なCSSプリプロセッサです。

LESSについての詳しい情報は以下のサイトで読むことができます:

http://lesscss.org/features/ (英語)
http://less-ja.studiomohawk.com/ (日本語)

CS-Cartでは、すべてのLESSの機能が使用出来るわけではありません。
どのような機能が使われているのかを理由とあわせて説明します。

Variables(変数)

変数を作成し、複数の場所で同じプロパティ値を使用することが出来ます。

例:

@price: #343434;

CS-CartのLESS変数はテーマのスタイルコンセプトに関連しています。( Styles and Visual Editor の項目を参照してください。)

CS-Cartがインストールされているディレクトリ以下のdesign/themes/THEME_NAME/styles/dataディレクトリにビジュアルエディタと関連のあるLESS 変数が含まれた .lessファイルがあります。

これらの値はファイルを直接編集するか、ビジュアル·エディタで編集することができます。

このディレクトリの.lessファイルの変数値はこのファイルでのみ編集可能です。

例えば、styles.lessファイルで定義された@price 変数は作動しません。
なぜなら、.../styles/data/.less ファイルに書かれた変数の値は、一番最後に読み込まれるためです。

Mixins(ミックスイン)

LESSにはMixinという複数のプロパティをまとめる機能があります。ミックスインはただのプロパティ値のひとつとしてクラス名を含む他のクラス内の全てのクラスのプロパティを含むことができます。

ミックスインは関数のように動作し、次の例のように引数を取ることができます:

rounded-corners (@radius: 5px) {
border-radius: @radius;
-webkit-border-radius: @radius;
-moz-border-radius: @radius;
}

#header {
.rounded-corners;
}
#footer {
.rounded-corners(10px);
}

Bootstrap2.3のミックスインのセットがCS-Cartでは使用されています。

design/themes/responsive/css/tygh ディレクトリのファイルにあるmixins.lessファイルに保存されています。

このファイルには、Utility mixinsとComponent mixinsがあります。

  • Utility mixins - 特定の使用目的のためのシンプルなミックスイン
  • Component mixins - グリッドを形成するために使用される複雑なミックスイン

ミックスインはCSSルールの記述を少なくすることが出来ます。ブラウザのベンダープレフィックスを用いるCSSプロパティのために使用されています。

Operations(演算)

この機能により、CSSルール内の数学的演算が可能です:
たし算、引き算、かけ算、割り算

例:

width: (900 / @columns)px;

Functions(関数)

LESSは、カラーコード、数学関数、関数を操作するための一連の関数が含まれています。

CS-Cartで使用されている操作:

  • lighten(@color, 10%) - 現在の色よりも10%明るい色を返します。

  • darken(@color, 10%) - 現在の色よりも10%暗い色を返します。

これらの操作は、スタイルとビジュアル·エディタに関連しています。

一つのベース色を基本色を明るくしたり、暗くしたりすることによって、他の要素の色を変更することができます。

  • percentage(0.5) - パーセント値に変換します。グリッドと列の作成中に使用されます。

Nested rules(入れ子)

「入れ子」は別の一つのCSSルールを囲むことが可能です。

ブラウザの開発ツールでの作業を複雑にしたのでCS-Cartでは、
ネストされたルールはほとんど使用されていません。

開発者ツールからコピーされネストされたルールを探す時、親ルールを考慮する必要があります。

その他のLESSの可能性については公式サイトで見ることができます:http://lesscss.org/features/

CS-CartではLESSのすべてが動作するわけではないことに注意してください。

CSSディレクトリ構造

利用中のテーマのCSSディレクトリへのパスはdesign/themes/THEME_NAMEです。

  • The css/addons directory - アドオンで追加されるスタイル

  • The css/lib directory - 他のライブラリのスタイル。Jqueryライブラリのスタイルがあります。

  • The css/typh directory - コア・スタイル

    • css/typh/reset.less - スタイルのリセット。Normalize.cssが使用されています。
    • css/typh/print.less - 印刷用のスタイル
    • ss/flags.less - 国旗用スタイル
    • css/design_mode.less - テンプレートやデザイン・モードで使用されているスタイル
    • css/theme_editor.less - ビジュアルエディタで使用されるスタイル
    • css/grid.css - 固定レイアウトのためのグリッドを形成するために使用される言語変数やミックスイン
    • css/mixins.less - LESSミックスインのセット

 

レスポンシブレイアウトに使用されるスタイル:

  • css/responsive-utilities.less - 表示または異なるデバイスの画面解像度のコンテンツを非表示にするために使用されているBootstrapクラス。

  • css/responsive.less - 異なる画面解像度のために使用されるスタイル。

主なファイルはstyles.lessです。テーマのスタイルが含まれています。css/typh に格納されたファイルは、@importオペレーターとstyles.less に含まれています。

CSSやLESSファイルの継承順

  1. design/themes/basic/templates/common/styles.tpl
  2. タグで*design/themes/basic/templates/common/styles.tpl*テンプレートに追加されたすべてのインラインスタイル。
  3. プリセットされたlessファイルが含まれています。
  4. ビジュアル·エディタのカスタムCSSフィールドに追加されたもの。
  5. アドオンのスタイルはプライオリティによって定義された順序で処理されます。

HTTPリクエスト数を減らすためにすべてのファイルが1つのcssファイル集約されます。

不便な点があるといえば、そのスタイルが書かれているファイルそのものを検索することです。:ファイルとdevツールを使用して検索するときに、各ファイルの行を検索することは出来ません。