SASSにおける@meidaディレクティブ
SASSにおけるディレクティブ@mediaは、CSSの対応するルールと同様に適用されます。また、CSSのすべてのルール内に直接ネストすることもできます。@mediaディレクティブをCSSルール内にネストする場合、コンパイル後にはスタイルシートの上部に移動し、ディレクティブが配置されていたセレクタは@media内に移動することに留意すべきです。これに基づいて、セレクタを繰り返したりスタイルシートのフローを乱したりすることなく、@mediaディレクティブ内にルールを追加することができます。
例を見てみましょう:
.navbar {
width: 400px;
@media picture and (orientation: portrait) {
width: 300px;
height: auto;
}
}
次に、コンパイル結果を見てみましょう:
.navbar {
width: 400px;
}
@media picture and (orientation: portrait) {
.navbar {
width: 300px;
height: auto;
}
}
@mediaクエリを互いにネストすることも可能で、コンパイル後にはそれらはand演算子で結合されます:
@media div {
.picture {
@media (orientation: portrait) {
width: 200px;
}
}
}
コンパイル後に得られる結果は以下の通りです:
@media div and (orientation: portrait) {
.picture {
width: 200px;
}
}
@mediaディレクティブのもう一つの特徴は、変数、関数、演算子を渡すために使用できることです:
$media: style;
$feature: -webkit-max-device;
$value: 3.0;
@media #{$media} and ($feature: $value) {
div {
color: red;
}
}
そして、style.cssファイルでは以下のコードが得られます:
@media style and (-webkit-max-device: 3) {
div {
color: red;
}
}
以下のコードをコンパイルした結果がどのようになるか説明してください:
.active-link {
color: blue;
@media content {
font-size: 14px;
text-decoration: underline;
}
}
以下のコードをコンパイルした結果がどのようになるか説明してください:
@media p {
#product-card {
@media (font-family: Arial) {
font-size: 12px;
}
}
#product-card-title {
@media (font-family: Arial) {
font-size: 14px;
font-weight: bold;
}
}
}
以下のコードをコンパイルした結果がどのようになるか説明してください:
$var: link;
$font: font-size;
$size: 10px;
@media #{$var} and ($font: $size) {
.block {
color: red;
}
}