Sass-クイックガイド

SASSとは何ですか?

SASS(Syntactically Awesome Stylesheet)はCSSプリプロセッサであり、CSSでの繰り返しを減らし、時間を節約するのに役立ちます。これは、ドキュメントのスタイルを明確かつ構造的に記述する、より安定した強力なCSS拡張言語です。

それは当初によって設計されました Hampton Catlin によって開発されました Natalie Weizenbaum 2006年。その後、 Weizenbaum そして Chris Eppstein 初期バージョンを使用して、SassScriptでSassを拡張しました。

SASSを使用する理由

  • これは、CSSのインデントされた構文(独自の構文)を提供する前処理言語です。

  • これは、コードをより効率的に記述し、保守が容易なスタイルシートの作成に使用されるいくつかの機能を提供します。

  • これはCSSのスーパーセットです。つまり、CSSのすべての機能が含まれており、オープンソースのプリプロセッサであり、 Ruby

  • フラットCSSよりも優れた構造化された形式でドキュメントスタイルを提供します。再利用可能なメソッド、論理ステートメント、および色操作、数学、パラメーターリストなどの組み込み関数の一部を使用します。

SASSの機能

  • より安定していて強力で、CSSのバージョンと互換性があります。

  • これはCSSのスーパーセットであり、JavaScriptに基づいています。

  • これはCSSのシンタックスシュガーとして知られており、ユーザーが物事をより明確に読んだり表現したりするためのより簡単な方法を意味します。

  • 独自の構文を使用し、読み取り可能なCSSにコンパイルします。

  • より少ない時間でより少ないコードでCSSを簡単に書くことができます。

  • これはオープンソースのプリプロセッサであり、CSSに解釈されます。

SASSの利点

  • これにより、プログラミング構造でクリーンなCSSを記述できます。

  • CSSをすばやく作成するのに役立ちます。

  • これはCSSのスーパーセットであり、設計者と開発者がより効率的かつ迅速に作業するのに役立ちます。

  • SassはCSSのすべてのバージョンと互換性があるため、利用可能なCSSライブラリを使用できます。

  • ネストされた構文と、色操作、数学、その他の値などの便利な関数を使用することができます。

SASSのデメリット

  • 開発者がこのプリプロセッサに存在する新機能を学ぶには時間がかかります。

  • 多くの人が同じサイトで作業している場合は、同じプリプロセッサを使用する必要があります。Sassを使用する人もいれば、CSSを使用してファイルを直接編集する人もいます。そのため、現場での作業が困難になります。

  • ブラウザの組み込み要素インスペクタの利点を失う可能性があります。

この章では、SASSファイルの実行に使用されるRubyをインストールするためのステップバイステップの手順を学習します。

SASSのシステム要件

  • Operating System −クロスプラットフォーム

  • Browser Support − IE(Internet Explorer 8以降)、Firefox、Google Chrome、Safari、Opera

  • Programming Language −ルビー

Rubyのインストール

Step 1 −リンクを開く https://www.ruby-lang.org/en/downloads/、以下のような画面が表示されます-

zipファイルの現在の安定バージョンをダウンロードします。

Step 2 −次に、セットアップを実行してインストールします Ruby システム上。

Step 3−次に、Ruby binフォルダーをPATHユーザー変数システム変数に追加して、gemコマンドを操作します。

Path User Variable

  • 右クリック My Computer アイコン。

  • 選択する Properties

  • 次に、をクリックします Advanced タブをクリックしてクリックします Environment Variables

では環境変数ウィンドウ、ダブルクリックPATHを下記のスクリーンショットのように-

図のように、[ユーザー変数の編集]ボックスが表示されます。変数値フィールドにルビービンフォルダパスを次のように追加しますC:\Ruby\bin。他のファイルのパスがすでに設定されている場合は、その後にセミコロンを置き、以下に示すようにRubyフォルダーのパスを追加します。

クリック OK ボタン。

System Variable

  • クリック New ボタン。

次に、 New System Variable 以下のようにブロックが表示されます。

  • 入る RubyOpt[変数名]フィールドとrubygems[変数値]フィールド。変数の名前値を書き込んだ後、をクリックしますOK ボタン。

Step 4 −システムでコマンドプロンプトを開き、次の行を入力します−

gem install sass

Step 5 −次に、SASSを正常にインストールすると、次の画面が表示されます。

以下はSASSの簡単な例です。

<html>
   <head>
      <title> Import example of sass</title>
      <link rel = "stylesheet" type = "text/css" href = "style.css"/>
   </head>

   <body>
      <h1>Simple Example</h1>
      <h3>Welcome to TutorialsPoint</h3>
   </body>
</html>

ここで、ファイルをstyle.scssとして作成します。これは、CSSと非常によく似ていますが、唯一の違いは、.scss拡張子で保存されることです。.htmファイルと.scssファイルの両方をフォルダー内に作成する必要がありますruby。.scssファイルをフォルダーに保存できますruby\lib\sass\ (このプロセスの前に、次のようにフォルダーを作成します sass libディレクトリ内)。

h1{
   color: #AF80ED;
}

h3{
   color: #DE5E85;
}

次のコマンドを使用して、SASSにファイルを監視し、SASSファイルが変更されるたびにCSSを更新するように指示できます。

sass --watch C:\ruby\lib\sass\style.scss:style.css

上記のコマンドを実行すると、style.cssファイルが自動的に作成されます。SCSSファイルを変更するたびに、style.cssファイルが自動的に更新されます。

style.cssには、あなたが上記のコマンドを実行すると、ファイルには、次のコードを持っています-

style.css

h1 {
   color: #AF80ED;
}
h3 {
   color: #DE5E85;
}

上記のコードがどのように機能するかを確認するために、次の手順を実行してみましょう-

  • 上記のコードをに保存します hello.html ファイル。

  • このHTMLファイルをブラウザで開きます。

この章では、SASSについて学習します Syntax。SASSは2つの構文をサポートしています。SCSS そして Indented syntax

  • ザ・ SCSS (Sassy CSS)CSS構文の拡張です。これは、すべての有効なCSSが有効なSCSSでもあることを意味します。SCSSは、大きなスタイルシートの保守をはるかに容易にし、ベンダー固有の構文を認識できます。多くのCSSおよびSCSSファイルは拡張子を使用します.scss

  • Indented −これは古い構文であり、単に次のように呼ばれることもあります。 SASS。この形式の構文を使用すると、CSSを簡潔に記述できます。SASSファイルは拡張子を使用します.sass

SASSインデント構文

SASSインデント構文または単にSASSは、CSSベースのSCSS構文の代替です。

  • ではなくインデントを使用します{ そして } ブロックを区切る。

  • ステートメントを区切るために、セミコロン(;)の代わりに改行を使用します

  • プロパティ宣言とセレクターは、独自の行とステートメント内に配置する必要があります{ そして }上に配置しなければならない新しいラインインデント

たとえば、次のSCSSコードについて考えてみます。

.myclass {
   color = red;
   font-size = 0.2em;
}

ザ・ indented構文は古い構文であり、新しいSassファイルでの使用はお勧めしません。このファイルを使用すると、以前使用したようにCSSファイルにエラーが表示されます= プロパティと変数を設定する代わりに。

次のコマンドを使用して、上記のコードをコンパイルします-

sass --watch C:\ruby\lib\sass\style.scss:style.css

次に、上記のコマンドを実行します。以下に示すように、style.cssファイルにエラーが表示されます-

Error: Invalid CSS after "  color = red": expected "{", was ";"
      on line 2 of C:\ruby\lib\sass\style17.scss

1:.myclass {
2:   color = red;
3:   font-size = 0.2em;
4:}

SASSの構文の違い

ほとんどのCSSおよびSCSS構文はSASSで完全に機能します。ただし、いくつかの違いがあり、次のセクションで説明します。

プロパティ構文

CSSプロパティは2つの方法で宣言できます-

  • プロパティはCSSと同様に宣言できますが、 semicolon(;)

  • colon(:) すべてのプロパティ名の前に付けられます。

たとえば、次のように書くことができます-

.myclass
   :color red
   :font-size 0.2em

デフォルトでは、上記の両方の方法(セミコロンとコロンをプロパティ名の前に付けないプロパティ宣言)を使用できます。ただし、:property_syntaxオプションを使用する場合、指定できるプロパティ構文は1つだけです。

マルチラインセレクター

インデントされた構文では、セレクターは、後に表示されるときはいつでも改行に配置できます。 commas

次の例では、SCSSファイルでの複数行セレクターの使用について説明します。

<html>
   <head>
      <title>Multiline Selectors</title>
      <link rel = "stylesheet" type = "text/css" href = "style.css" />
      <link rel = "stylesheet" href = "https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/css/bootstrap.min.css">
      <script src = "https://ajax.googleapis.com/ajax/libs/jquery/2.1.3/jquery.min.js"></script>
      <script src = "https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/js/bootstrap.min.js"></script>
   </head>
   
   <body>
      <h2>Example using Multiline Selectors</h2 >
      <p class = "class1">Welcome to Tutorialspoint!!!</p>
      <p class = "class2">SASS stands for Syntactically Awesome Stylesheet...</p>
   </body>
</html>

次に、ファイルstyle.scssを作成します。.scss拡張子に注意してください。

style.scss

.class1,
.class2{
   color:red;
}

次のコマンドを使用して、SASSにファイルを監視し、SASSファイルが変更されるたびにCSSを更新するように指示できます。

sass --watch C:\ruby\lib\sass\style.scss:style.css

次に、上記のコマンドを実行すると、次のコードでstyle.cssファイルが自動的に作成されます-

生成されたstyle.cssは以下のとおりです-

style.css

.class1,
.class2 {
   color: red;
}

出力

上記のコードがどのように機能するかを確認するために、次の手順を実行してみましょう-

  • 上記のhtmlコードをmultiline_selectors.htmlファイルに保存します。

  • このHTMLファイルをブラウザで開くと、以下のような出力が表示されます。

コメント

コメントは1行全体を占め、その下にネストされたすべてのテキストを囲みます。それらはインデントされた構文で行ベースです。コメントの詳細については、このリンクを参照してください。

@インポート

SASSでは @importディレクティブは引用符付き/引用符なしで記述できます。SCSSとは異なり、引用符で囲む必要があります。

たとえば、SCSSでは @import ディレクティブは次のように使用できます-

@import "themes/blackforest";
@import "style.sass";

これはSASSで次のように書くことができます-

@import themes/blackforest
@import fontstyle.sass

Mixinディレクティブ

SASSは次のようなディレクティブの省略形をサポートします @mixin そして @include。の代わりに@mixin そして @include あなたが使用することができます = そして + 文字。入力が少なくて済み、コードがシンプルで読みやすくなります。

たとえば、ミックスインディレクティブは次のように記述できます。

=myclass
   font-size: 12px;
p
   +myclass

上記のコードは-と同じです

@mixin myclass
   font-size: 12px;
p
   @include myclass

非推奨の構文

SASSはいくつかの古い構文の使用をサポートしています。ただし、SASSでこの構文を使用するとnot recommended。この構文を使用すると警告が表示され、それ以降のバージョンでは削除されます。次の表に、古い構文の一部を示します。

S.いいえ。 オペレーターと説明
1

=

変数とプロパティをSassScriptの値に設定するときに、:の代わりに使用されました。

2

||=

変数のデフォルト値を割り当てるときはいつでも、:の代わりに使用されました。

3

!

$の代わりに!変数プレフィックスとして使用されました。$の代わりに使用しても、機能は変更されません。

SASSはより強力で安定しており、CSSの拡張機能を使用して基本言語に電力を供給します。SASSは3つの異なる方法で使用できます-

  • コマンドラインツールとして
  • Rubyモジュールとして
  • Rackenableフレームワークのプラグインとして

WindowsでSASSを使用している場合は、インストールする必要があります Ruby最初。Rubyのインストールの詳細については、SASSのインストールの章を参照してください。

次の表に、SASSコードの実行に使用されるコマンドを示します。

S.いいえ。 コマンドと説明
1

sass input.scss output.css

コマンドラインからSASSコードを実行するために使用されます。

2

sass --watch input.scss:output.css

SASSにファイルを監視し、SASSファイルが変更されるたびにCSSを更新するように通知します。

3

sass --watch app/sass:public/stylesheets

SASSのディレクトリに多くのファイルが含まれている場合、ディレクトリ全体を監視するために使用されます。

ラック/レール/ Merbプラグイン

RackRubyでWebアプリケーションを開発するために使用されるWebサーバーインターフェイスです。Rackの詳細については、このリンクにアクセスしてください。

SASSを有効にするには Rails 3 を使用したバージョン environment.rb 下に存在するファイル configフォルダ。次のコードを使用して、Rails3のSASSを有効にします-

config.gem "sass"

Rails 3(およびそれ以降のバージョン)のGemfileに対して、次の行を次のように使用できます。

gem "sass"

Railsは、JSON、HTML、CSS、JavaScriptなどのWeb標準を使用してユーザーインターフェイスを表示するオープンソースのWebフレームワークです。Railsを使用するには、Rubyとオブジェクト指向プログラミングの基本的な知識が必要です。Railsフレームワークの詳細についてはこちらをご覧ください。

でSASSを有効にする場合 Rack アプリケーションで、次の行をに追加します config.ru アプリのルートディレクトリにあるファイル-

require 'sass/plugin/rack'
use Sass::Plugin::Rack

MerbRailsに速度とモジュール性を提供するWebアプリケーションフレームワークです。Merbの詳細については、このリンクを開いてください。

SASSを有効にするには Merb 次の行をに追加します config/dependencies.rb ファイル-

dependency "merb-haml"

キャッシング

SASSは、テンプレートやパーシャルなどのドキュメントをキャッシュします。これらのドキュメントは、変更されていない限り、解析せずに再利用できます。テンプレートを別々のファイルに分割し、それらをすべて1つの大きなファイルにインポートすると、SASSファイルのコンパイルが高速になり、さらにうまく機能します。キャッシュされたファイルを削除すると、次回のコンパイル時に再度生成されます。

オプション

次の行を使用して、Railsのenvironment.rbファイルまたはRackアプリケーションのconfig.ruファイルでオプションを設定できます。

Sass::Plugin.options[:style] = :compact

次の行を使用して、Merbのinit.rbファイルにオプションを設定することもできます-

Merb::Plugin.config[:sass][:style] = :compact

以下の表で説明されているように、SASSおよびSCSSで使用可能ないくつかのオプションがあります-

S.いいえ。 オプションと説明
1

:style

出力のスタイルを表示します。

2

:syntax

sassにはインデント構文を使用し、scssにはCSS拡張構文を使用できます。

3

:property_syntax

インデントされた構文を使用してプロパティを利用します。正しくない場合は、エラーがスローされます。たとえば、「background:#F5F5F5」について考えてみます。ここで、backgroundはプロパティ名であり、#F5F5F5はそのプロパティ値です。プロパティ名の後にコロンを使用する必要があります。

4

:cache

SASSファイルのコンパイルを高速化します。デフォルトではtrueに設定されています。

5

:read_cache

キャッシュが設定されておらず、read_cacheが設定されている場合は、SASSファイルのみを読み取ります。

6

:cache_store

Sass :: CacheStores :: Baseのインスタンスに設定することで、キャッシュされた結果を保存してアクセスするために使用できます。

7

:never_update

テンプレートファイルが変更された場合、CSSファイルを更新しないでください。デフォルトではfalseに設定されています。

8

:always_update

テンプレートファイルが変更されるたびにCSSファイルを更新する必要があります。

9

:always_check

サーバーが起動するたびに更新を確認する必要があります。SASSテンプレートファイルに更新がある場合は、CSSファイルを再コンパイルして上書きします。

10

:poll

これは、trueに設定することにより、Sass :: Plugin :: Compiler#watch(テンプレートとCSSファイルの更新を監視する)のポーリングバックエンドを使用します。

11

:full_exception

生成されたCSSファイル内のSASSコードで例外が発生するたびに、エラーの説明が表示されます。CSSファイルのソースとともにエラーが発生した行番号を表示します。

12

:template_location

これは、アプリケーションのテンプレートディレクトリへのパスを提供します。

13

:css_location

これは、アプリケーションのCSSスタイルシートへのパスを提供します。

14

:unix_newlines

trueに設定することにより、ファイルを書き込むときにUnixスタイルの改行を提供します。

15

:filename

これは、表示され、エラーの報告に使用されるファイル名の名前です。

16

:line

SASSテンプレートの最初の行を指定し、エラーの行番号を表示します。

17

:load_paths

@importディレクティブを使用して含まれるSASSテンプレートのパスをロードするために使用されます。

18

:filesystem_importer

これは、Sass :: Importers :: Baseサブクラスを使用して文字列のロードパスを処理するファイルシステムからファイルをインポートするために使用されます。

19

:sourcemap

SASSスタイルを見つけるようにブラウザに指示するソースマップを生成します。3つの値を使用します-

  • :auto−相対URIが含まれています。相対URIがない場合は、「file:」URIを使用します。

  • :file −リモートサーバーではなくローカルで機能する「file:」URIを使用します。

  • :inline −大きなソースマップファイルを作成するために使用されるソースマップにソーステキストが含まれています。

20

:line_numbers

trueに設定すると、CSSファイルで報告されたエラーの行番号が表示されます。

21

:trace_selectors

trueに設定されている場合、インポートとミックスインのセレクターをトレースするのに役立ちます。

22

:debug_info

trueに設定されている場合、行番号とファイルを使用してSASSファイルのデバッグ情報を提供します。

23

:custom

個別のアプリケーションのSASS機能でデータを利用できるようにします。

24

:quiet

trueに設定すると、警告が無効になります。

構文の選択

SASSコマンドラインツールを使用して、SASSテンプレートで使用している構文を判別できます。デフォルトでは、SASSはCSSベースのSCSS構文の代わりとなるインデント構文を使用します。SASSプログラムに似たSCSSコマンドラインプログラムを使用できますが、デフォルトでは、構文はSCSSと見なされます。

エンコーディング

SASSは、次のCSS仕様を指定することにより、スタイルシートの文字エンコードを使用します-

  • 最初にUnicodeバイトをチェックし、次に@charset宣言をチェックし、次にRuby文字列エンコーディングをチェックします。

  • 次に、何も設定されていない場合は、文字セットエンコーディングをUTF-8と見なします。

  • @charset宣言を使用して、文字エンコードを明示的に決定します。スタイルシートの冒頭で「@charsetencodingname」を使用するだけで、SASSはこれが指定された文字エンコードであると想定します。

  • SASSの出力ファイルに非ASCII文字が含まれている場合は、@ charset宣言が使用されます。

この章では、 CSS Extensions。CSS拡張機能を使用して、Webページの機能を強化できます。次の表に、SASSで使用されるCSS拡張機能の一部を示します。

S.いいえ。 CSSの拡張機能と説明
1 ネストされたルール

これは、複数のCSSルールを相互に組み合わせる方法です。

2 親セレクターの参照:&

これは、を使用して親セレクターを選択するプロセスです。 & キャラクター。

3 ネストされたプロパティ

プロパティを他のプロパティにネストして、別の関連コードをグループ化することができます。

4 プレースホルダーセレクター

Sassは、@ extendディレクティブを使用してクラスまたはIDセレクターを使用するプレースホルダーセレクターをサポートします。

この章では、Sassについて学習します Comments。コメントは実行不可能なステートメントであり、ソースコードに配置されます。コメントはソースコードを理解しやすくします。SASSは2種類のコメントをサポートしています。

  • Multiline comments−これらは/ *および* /を使用して記述されます。複数行コメントはCSS出力に保持されます。

  • Single line comments −これらは以下を使用して書かれています //コメントが続きます。単一行コメントはCSS出力に保持されません。

次の例は、SCSSファイルでのコメントの使用を示しています-

<html>
   <head>
      <title>SASS comments</title>
      <link rel = "stylesheet" type = "text/css" href = "style.css"/>
   </head>

   <body>
      <h1>Welcome to TutorialsPoint</h1>
      <a href = "http://www.tutorialspoint.com/">TutorialsPoint</a>
   </body>
</html>

次に、ファイルstyle.scssを作成します。

style.scss

/* This comment is
 * more than one line long
 * since it uses the CSS comment syntax,
 * it will appear in the CSS output. */
body { color: black; }

// These comments are in single line
// They will not appear in the CSS output,
// since they use the single-line comment syntax.
a { color: blue; }

次のコマンドを使用して、SASSにファイルを監視し、SASSファイルが変更されるたびにCSSを更新するように指示できます。

sass --watch C:\ruby\lib\sass\style.scss:style.css

次に、上記のコマンドを実行すると、次のコードでstyle.cssファイルが自動的に作成されます-

style.css

/* This comment is
 * more than one line long
 * since it uses the CSS comment syntax,
 * it will appear in the CSS output. */
body {
   color: black; }

a {
   color: blue; }

出力

上記のコードがどのように機能するかを確認するために、次の手順を実行してみましょう-

  • 上記のhtmlコードをに保存します sass_comments.html ファイル。

  • このHTMLファイルをブラウザで開くと、以下のような出力が表示されます。

複数行コメント内の補間について調べるには、このリンクをクリックしてください。

Sass –複数行コメントの補間

説明

複数行コメント内の補間は、結果のCSSで解決されます。中括弧内に変数またはプロパティ名を指定できます。

構文

$var : "value";
/* multiline comments #{$var} */

次の例は、SCSSファイルの複数行コメントでの補間の使用を示しています。

<html>
   <head>
      <title>SASS comments</title>
      <link rel = "stylesheet" type = "text/css" href = "style.css"/>
   </head>

   <body>
      <h1>Welcome to TutorialsPoint</h1>
      <p>This is an example for Interpolation in SASS.</p>
   </body>
</html>

次に、ファイルstyle.scssを作成します。

style.css

$version: "7.8";
/* Framework version for the generated CSS is #{$version}. */

次のコマンドを使用して、SASSにファイルを監視し、SASSファイルが変更されるたびにCSSを更新するように指示できます。

sass --watch C:\ruby\lib\sass\style.scss:style.css

次に、上記のコマンドを実行します。次のコードでstyle.cssファイルを自動的に作成します

style.css

/* Framework version for the generated CSS is 7.8. */

出力

上記のコードがどのように機能するかを確認するために、次の手順を実行してみましょう-

  • 上記のhtmlコードをに保存します sass_comments_interpolation.htm ファイル。

  • このHTMLファイルをブラウザで開くと、以下のような出力が表示されます。

SASSは、SASSドキュメントに含めることができるSassScriptと呼ばれる拡張機能の小さなセットを使用して、プロパティ値から変数を計算し、変数、算術、およびその他の関数のプロパティを使用します。SassScriptは、ミックスインの使用中にセレクターとプロパティ名とともに使用することもできます(Mixinsを使用すると、スタイルシート全体でCSSスタイルを再利用できます)。

次の表に、SASSで使用されるCSS拡張機能の一部を示します。

S.いいえ。 CSSの拡張機能と説明
1 インタラクティブシェル

コマンドラインを使用してSassScript式を評価します。

2 変数

数値、文字、メモリアドレスなどのデータを表します。

3 DataTypes

すべてのデータオブジェクトのデータ型を宣言します。

4 操作

数値、色、文字列、ブール値、リスト操作などの操作を提供します。

5 括弧

これは、通常、丸括弧()または角括弧[]でマークされている記号のペアです。

6 関数

いくつかのキーワード引数を提供することにより、関数の使用をサポートします。

7 補間

を使用してSassScript変数とプロパティ名を提供します #{ } 構文。

8 &SassScriptで

これにより、プロパティを別のプロパティにネストして、別の関連コードのグループ化を行うことができます。

9 変数のデフォルト

これにより、プロパティを別のプロパティにネストして、別の関連コードのグループ化を行うことができます。

次の表に、SASSで使用できるすべてのルールとディレクティブを示します。

S.いいえ。 ディレクティブと説明
1 @インポート

SASSまたはSCSSファイルをインポートし、インポートするファイル名を直接取得します。

2 @メディア

スタイルルールをさまざまなメディアタイプに設定します。

3 @extend

@extendディレクティブは、セレクター間でルールと関係を共有するために使用されます。

4 @ at-root

@ at-rootディレクティブは、ネストされたルールのコレクションであり、ドキュメントのルートでスタイルブロックを作成できます。

5 @デバッグ

@debugディレクティブはエラーを検出し、SassScript式の値を標準エラー出力ストリームに表示します。

6 @警告

@warnディレクティブは、問題に関する注意深いアドバイスを提供するために使用されます。SassScript式の値を標準エラー出力ストリームに表示します。

7 @エラー

@errorディレクティブは、SassScript式の値を致命的なエラーとして表示します。

この章では、 Control Directives & Expressions。SassScriptでサポートされている制御ディレクティブと式を使用することで、いくつかの条件に基づいたスタイリングや、バリエーションのある同じスタイルを何度も適用することができます。これらの制御ディレクティブは、主にミックスインで使用される高度なオプションです。それらはCompassライブラリの一部であるため、かなりの柔軟性が必要です。

次の表に、SASSで使用される制御ディレクティブと式を示します。

S.いいえ。 説明付きの制御指令と表現
1 if()

条件に基づいて、if()関数は2つの可能な結果から1つの結果のみを返します。

2 @if

@IfのディレクティブはSassScript式を受け入れ、式の結果が以外の場合は常に、ネストされたスタイルを使用して、偽またはヌル

3 @にとって

@Forディレクティブを使用すると、ループ内のスタイルを生成することができます。

4 @各

@each指令、変数は、リスト内の各項目の値を含む定義されています。

5 @while

SassScript式を取り、ステートメントがfalseと評価されるまで、ネストされたスタイルを繰り返し出力します。

ミックスインを使用すると、スタイルのグループを作成できます。これらのスタイルは、非セマンティッククラスを再作成することなく、スタイルシート全体で再利用できます。CSSでは、ミックスインは複数の値またはパラメーターを格納し、関数を呼び出すことができます。繰り返しコードを書かないようにするのに役立ちます。ミックスイン名では、アンダースコアとハイフンを同じ意味で使用できます。以下は、Mixinsに存在するディレクティブです-

S.いいえ。 指令と説明
1 Mixinの定義

@mixinディレクティブは、ミックスインを定義するために使用されます。

2 Mixinを含む

@includeディレクティブは、ドキュメントにミックスインを含めるために使用されます。

3 引数

SassScript値は、ミックスインの引数として使用できます。これは、ミックスインが含まれている場合に指定され、ミックスイン内で変数として使用できます。

4 コンテンツブロックをミックスインに渡す

スタイルのブロックがミックスインに渡されます。

この章では、 Function Directives。SASSでは、独自の関数を作成してスクリプトコンテキストで使用することも、任意の値で使用することもできます。関数は、関数名と任意のパラメーターを使用して呼び出されます。

次の例は、SCSSファイルでの関数ディレクティブの使用を示しています-

function_directive.htm

<html>
   <head>
      <title>Nested Rules</title>
      <link rel = "stylesheet" type = "text/css" href = "style.css" />
      <link rel = "stylesheet" href = "https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/css/bootstrap.min.css">
      <script src = "https://ajax.googleapis.com/ajax/libs/jquery/2.1.3/jquery.min.js"></script>
      <script src = "https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/js/bootstrap.min.js"></script>
   </head>

   <body>
      <div class = "container" id = "set_width">
         <h2>Example for Function directives</h2>
         <p>SASS stands for Syntactically Awesome Stylesheet. </p>
      </div>
   </body>
</html>

次に、ファイルstyle.scssを作成します。

style.scss

$first-width: 5px;
$second-width: 5px;

@function adjust_width($n) {
   @return $n * $first-width + ($n - 1) * $second-width;
}

#set_width { padding-left: adjust_width(10); }

次のコマンドを使用して、SASSにファイルを監視し、SASSファイルが変更されるたびにCSSを更新するように指示できます。

sass --watch C:\ruby\lib\sass\style.scss:style.css

次に、上記のコマンドを実行します。次のコードでstyle.cssファイルを自動的に作成します-

style.css

#set_width {
   padding-left: 95px; 
}

出力

上記のコードがどのように機能するかを確認するために、次の手順を実行してみましょう-

  • 上記のhtmlコードをに保存します function_directive.html ファイル。

  • このHTMLファイルをブラウザで開くと、以下のような出力が表示されます。

出力では、左パディングが適用されていることがわかります。

ミックスインと同様に、関数もグローバルに定義された変数にアクセスでき、パラメーターを受け入れることもできます。を使用して関数の戻り値を呼び出す必要があります@return。キーワードパラメータを使用して、SASS定義の関数を呼び出すことができます。

以下に示すように、上記の関数を呼び出します。

#set_width { padding-left: adjust_width($n: 10); }

命名規則

名前の競合を回避するために、関数名に接頭辞を付けて、簡単に区別できるようにすることができます。ミックスインと同様に、変数引数もユーザー定義関数でサポートされています。関数と他のSASS識別子は、アンダースコア(_)とハイフン(-)を同じ意味で使用できます。

たとえば、関数が次のように定義されている場合 adjust_width、それはとして使用することができます adjust-width、 およびその逆。

この章では、 SASS Output Style。SASSが生成するCSSファイルは、ドキュメントの構造を反映するデフォルトのCSSスタイルで構成されています。デフォルトのCSSスタイルは適切ですが、すべての状況に適しているとは限りません。一方、SASSは他の多くのスタイルをサポートしています。

次の異なる出力スタイルをサポートします-

:nested

ネストされたスタイルは、SASSのデフォルトのスタイルです。このスタイル設定の方法は、大きなCSSファイルを扱うときに非常に役立ちます。これにより、ファイルの構造が読みやすくなり、簡単に理解できるようになります。すべてのプロパティには独自の行があり、各ルールのインデントは、ネストの深さに基づいています。

たとえば、以下に示すように、SASSファイルにコードをネストできます。

#first {
   background-color: #00FFFF;
   color: #C0C0C0; 
}

#first p {
   width: 10em; 
}

.highlight {
   text-decoration: underline;
   font-size: 5em;
   background-color: #FFFF00; 
}

:拡張

拡張タイプのCSSスタイルでは、各プロパティとルールに独自の行があります。ネストされたCSSスタイルと比較してより多くのスペースが必要です。[ルール]セクションはプロパティで構成されており、これらはすべてルール内で意図されていますが、ルールはインデントに従いません。

たとえば、以下に示すように、SASSファイルのコードを展開できます。

#first {
   background-color: #00FFFF;
   color: #C0C0C0;
}

#first p {
   width: 10em;
}

.highlight {
   text-decoration: underline;
   font-size: 5em;
   background-color: #FFFF00;
}

:コンパクト

コンパクトなCSSスタイルは、Expanded andNestedよりもスペースを節約できます。プロパティではなく、主にセレクターに焦点を当てています。各セレクターは1行を占め、そのプロパティも同じ行に配置されます。ネストされたルールは改行なしで隣り合って配置され、ルールの個別のグループには改行があります。

たとえば、以下に示すように、SASSファイルのコードを圧縮できます。

#first { 
   background-color: #00FFFF; color: #C0C0C0; 
}

#first p { 
   width: 10em; 
}

.highlight { 
   text-decoration: underline; font-size: 5em; background-color: #FFFF00; 
}

:圧縮

圧縮されたCSSスタイルは、上記の他のすべてのスタイルと比較して、必要なスペースが最小です。ファイルの最後にあるセレクターと改行を区切るためにのみ空白を提供します。このスタイルの方法は混乱を招き、簡単に読むことはできません。

たとえば、以下に示すように、SASSファイルのコードを圧縮できます。

#first { 
   background-color:#00FFFF;color:#C0C0C0
} 

#first p { 
   width:10em 
} 

.highlight { 
   text-decoration:underline;font-size:5em;background-color:#FFFF00 
}

SASSの機能を拡張して、さまざまなタイプの機能とカスタマイズをユーザーに提供できます。これらの機能を利用するには、ユーザーはRubyの知識を持っている必要があります。

カスタムSASS関数の定義

Ruby APIを使用しながら、独自のSASS関数を定義できます。次のコードに示すように、カスタム関数をRubyメソッドに追加することで、カスタム関数を追加できます。

module Sass::Script::Functions
   def reverse(string)
      assert_type string, :String
      Sass::Script::Value::String.new(string.value.reverse)
   end
   declare :reverse, [:string]
end

表示されているコードでは、Function宣言により、関数の引数名が指定されています。失敗した場合、関数が機能していても引数を受け入れず、任意のキーワード引数も取ります。アクセサーを使用してRuby値を取得し、rgb、red、green、またはblueを使用してカラーオブジェクトにアクセスできます。

キャッシュストア

SASSは、解析されたドキュメントのキャッシュを保存します。これは、再度解析せずに再利用できます。SASSは:cache_locationファイルシステムにキャッシュファイルを書き込む。SASSファイルのコンパイルが高速になり、キャッシュされたファイルを削除すると、次回のコンパイル時に再度生成されます。を設定することにより、独自のキャッシュストアを定義できます。:cache_storeオプション。これにより、ファイルシステムにキャッシュファイルが書き込まれるか、キャッシュファイルがrubyプロセスまたはマシンと共有されます。SASSは、Sass :: CacheStores :: Baseのサブクラスのインスタンスを使用して、キャッシュ結果を保存および取得します。

カスタムインポーター

SASSは@importを使用してSCSSファイルとSASSファイルをインポートし、パスを@importルールに渡して、指定されたパスに適切なパスコードを見つけます。SASSインポーターは、ファイルシステムを使用してコードをロードし、データベースまたは別のファイル命名スキームを使用してロードに追加します。

単一のインポーターは単一のファイルのロードを行うことができ、ファイルシステムのパスとともに:load_paths配列に配置できます。@importを使用している間、SASSはロードされたパスを探します。ロードされたパスはインポーターのパスをインポートします。パスが見つかると、インポートされたファイルが使用されます。ユーザーはからインポーターを継承できますSass::Importers::Base