質問をすることでしか得られない、回答やアドバイスがある。

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

新規登録して質問してみよう
ただいま回答率
85.35%
HTML

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

CSS

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

Q&A

解決済

1回答

1737閲覧

CSSでプロパティが効かない理由

退会済みユーザー

退会済みユーザー

総合スコア0

HTML

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

CSS

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

0グッド

0クリップ

投稿2020/05/02 05:17

編集2020/05/02 05:29

おそらく超初歩的なかもしれませんが、CSSのスキルアップのために是非教えてください。

実在するサイトの模写を作ってコーディングの練習をしているのですが、時々うまくスタイルが反映されないということがあります。
大抵は書き直して、どうにかするのですが効率が下がってしまうので、ルールをしっかりと理解したいと思います。

例えば下記のコード
aタグ内に「こんにちは」というテキストがあり、それを囲むpタグ文字に関するプロパティをつけてみました。しかし、「こんにちは」にスタイルは適用されませんでした。aタグに書いたら適用されました。

この場合、pタグに書いたクラスの内容はなぜ継承されないのでしょうか。
また、こういったちょっとしたミスをなくすためにはCSS/HTMLの何を理解すべきでしょうか。

よろしくお願い致します。

追記:すみません、どうやらその時は何かしら他の点でミスをしていた可能性が高かったようです。今検証してみると文字色以外はどうやら適用されました。(記載したcssプロパティ)

<p class="hello">  <a href="#">こんにちはこんにちは</a> </p>
.hello{ font-family:"遊ゴシック"; font-size:1.6rem; color:#fff; line-height:2; }

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

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

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

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

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

kei344

2020/05/02 05:22

(質問文は編集できます)具体的になにが継承されていて何が継承されていませんか?
退会済みユーザー

退会済みユーザー

2020/05/02 05:31

申し訳ないです。質問に記載した通り、どうやら文字色以外は適用されました(文字色はリンクタグの青色のまま) もしかしたら、aタグを囲んだテキストは親要素のブロック要素にプロパティをしても継承されない・・・?みたいな疑いをかけていたようです。
guest

回答1

0

ベストアンサー

こんにちは。

CSSではご存知かもしれませんがスタイルの継承というものがあります。
では、実際に例を見て確認してみましょう。

html

1<body> 2 <h1>スタイルの継承</h1> 3 <p>hello world</p> 4</body>

bodyにcolorプロパティを指定して文字色を赤色にしてみます。
bodyの子要素にはh1タグとpタグでいくつかダミー文を用意します。

ブラウザで確認してみるとh1タグやpタグに直接スタイリングしていなくても文字色は赤色になっているかと思います。
これがスタイルの継承です。

では、全てのプロパティがスタイルの継承をするかと思うかもしれませんが、スタイルの継承ができないプロパティも中にはあります。ではそちらも確認してみましょう。

先ほどのHTMLにborderプロパティを指定してみましょう。
bodyに対しては境界線が付いているかと思いますが、h1やpに対しては境界線がついていないかと思います。

これは、borderプロパティはスタイルの継承がされていない。ということになります。

では、継承がされるプロパティなのかそれともされないのかはMDNという仕様がまとめられているサイトで確認することができます。

今回は先ほど挙げた二つのプロパティで確認してみます。

colorプロパティ
どこをみるかというと仕様書という見出しがあるのでそちらをご参照ください。
colorプロパティ
この様に継承ありと書かれており、スタイルの継承はあるということが分かります。

では、先ほど継承が行われなかったborderプロパティを確認してみましょう。
borderプロパティ

イメージ説明
先ほどと同じ場所を参照すると継承なしと書かれています。

この様にスタイルの継承には継承されるものとされないものがあるのでそちらとその仕様を確認できる様にしときましょう。

投稿2020/05/02 06:00

編集2020/05/02 06:20
kai0310

総合スコア2076

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

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

退会済みユーザー

退会済みユーザー

2020/05/02 06:15

ありがとうございます!プロパティによって継承があるものとないのがあるんですね。。。 確かに、borderが全てに継承されたらとんでもないことになりそうです。 少しずつこんな物もあるんだと理解していきます。分かりやすい内容ありがとうございます。
kai0310

2020/05/02 06:16

解決された様で何よりです
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問