🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Sass

Sassは、プログラミング風のコードでCSSを生成できるスタイルシート言語です。 scss ファイルを、変換(コンパイル)してCSSファイルを作成します。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

Q&A

解決済

2回答

1134閲覧

SCSSで入れ子構造にすると、背景色や文字色が反映されない

ErioYsd

総合スコア4

Sass

Sassは、プログラミング風のコードでCSSを生成できるスタイルシート言語です。 scss ファイルを、変換(コンパイル)してCSSファイルを作成します。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

0グッド

0クリップ

投稿2020/12/08 03:38

SCSSについて、背景色や文字色が反映されないので教えてください。
基本の文字色を黒として、

SCSS

1$FontPink: #ff8780; 2$LightPink: #fff1e9; 3 4article { 5 h1 { 6 height: 60px; 7 vertical-align: middle; 8 font-size: 60px; 9 span { 10 font-size: 32px; 11 vertical-align: 25%; 12 } 13 } 14 .pink { 15 .bg { 16 background-color: $LightPink; 17 } 18 h1, h1 span { 19 color: $FontPink; 20 } 21 } 22}

とSCSSで下記、コンバート後は下記になりました。

CSS

1article { 2 article h1 { 3 height: 60px; 4 vertical-align: middle; 5 font-size: 60px; } 6 article h1 span { 7 font-size: 32px; 8 vertical-align: 25%; } 9 article .pink .bg { 10 background-color: #fff1e9; } 11 article .pink h1, article .pink h1 span { 12 color: #ff8780; }

HTMLがこうなっているのですが、divの背景色やh1の文字色が反映されません。

HTML

1<article class="pink"> 2 <h1>01|<span>サンプル</span></h1> 3 <div class="bg"> 4 サンプルです。<br> 5 サンプルな感じです。<br> 6 </div> 7</article>

背景色や文字色を反映させるにはどのようにすれば良いでしょうか?

articleのclass名を”pink”としていますが、これを"green"に変更すると、背景色やh1の文字色も緑系統に変わる……という風にCSSを整頓したいと思っています。

よろしくお願いします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

下記の修正をしてください。

diff

1- .pink { 2+ &.pink {

コンパイル後は、

diff

1- article .pink .bg { 2+ article.pink .bg {

article .pink だと article の子孫要素のpinkクラスという意味になります。

article.pink で article要素でpinkクラスのついたものということです。

投稿2020/12/08 04:51

hatena19

総合スコア34073

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

ErioYsd

2020/12/08 08:56

解決しました! 本当にありがとうございました!
guest

0

.pink の前に & を入れると良いかと思います。

scss

1 &.pink { 2 .bg { 3 background-color: $LightPink; 4 } 5 h1, h1 span { 6 color: $FontPink; 7 } 8 }

現状はコンバートすると...

css

1article .pink .bg { 2 background-color: #fff1e9; }

「article の子要素で .pink の子孫要素 .bg の background-color を指定」している記述になっていますが、上記のscssのようにすると以下のように
「article かつ pink クラスを持っている、の子孫要素の .bg の background-color を指定」する記述となります。

css

1article.pink .bg { 2 background-color: #fff1e9; }

article と .pink の間のスペースある無しでセレクタの意味が変わります。

投稿2020/12/08 04:49

natsu_

総合スコア78

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

ErioYsd

2020/12/08 08:59

丁寧な解説まで含めありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問