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

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

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

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

CSS

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

Q&A

解決済

2回答

637閲覧

クラス名と擬似クラスを同時に指定は出来ないでしょうか

sor

総合スコア17

CSS3

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

CSS

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

0グッド

0クリップ

投稿2020/04/13 02:08

表題の通りです。
同じクラス名の中で擬似クラスを指定した所、
思った通りの挙動にならなかったため下記のようにテストをしました。

■ベース

<p class="aaa">1番目</p> <p class="aaa">2番目</p> <p class="aaa">3番目</p> p:first-of-type{ color:red; } → 1番目が赤 p.aaa:first-of-type{ color:red; } → 1番目が赤

■ベースの上にイレギュラーな要素を追加

<p>イレギュラー(追加)</p> <p class="aaa">1番目</p> <p class="aaa">2番目</p> <p class="aaa">3番目</p> p:first-of-type{ color:red; } → イレギュラーが赤 p.aaa:first-of-type{ color:red; } → 赤になるものは無し ※p.aaa:first-of-type を下記2点に変えてみても結果は同じでした。  ・p.aaa:nth-of-type(1){ color:red; }  ・p[class="aaa"]:first-of-type{ color:red; }

■結果と実現したいこと

理想 → class名[aaa]の中の1番目が赤くなる
実際 → class名[aaa]、なおかつ 要素の1番目じゃないと赤くならない

class名が無視されているのかと思いきや、
イレギュラーが入った方でclass名と疑似クラスを両方指定した場合は赤くなるのが無い状態です。

実務でイレギュラーのように同じ要素(違うclass名)が一番上に追加されることがあるため困っているのですが、
理想の「class名aaaの中の1番目が赤くなる」という挙動をcssのみで制御するのは無理なのでしょうか?

ご教示の程よろしくお願いいたします。

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

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

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

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

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

guest

回答2

0

ベストアンサー

はい、:first-of-typetypeタイプセレクタ(HTMLではpなどの要素セレクタ)を意味しています(CSS4)。「特定のクラスを満たす最初の要素」に使うことはできません。

投稿2020/04/13 02:23

編集2020/04/13 02:24
maisumakun

総合スコア146018

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

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

sor

2020/04/13 04:26

やはり特定のclass内で、という判定は出来ないのですね。。 現状では使うのが難しそうですがorの書き方があるのは初めて知りました! イレギュラーが発生しても問題無いようcssを組みなおしたいと思います。 ご回答ありがとうございました!
guest

0

単純に「p.aaa:first-of-type」は
「兄弟要素のグループの中でその種類の最初の要素」のウチ「クラスaaaを持つもの」という
解釈をされます

投稿2020/04/13 02:52

yambejp

総合スコア116724

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

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

sor

2020/04/13 04:26

解釈の順番が逆だったのですね。。 逆に言うと最初の要素のclass名によってcssを分ける事は出来そうなので、 どうにかcssを組みなおしたいと思います。 ご回答ありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問