カテゴリー
WordPressカスタマイズ

CSS 親要素へのスタイル指定

「特定要素の親を指定する」 できると便利なのにな~というケースがありますよね。
CSS4 であらたに定義される擬似クラス:has()でこれが可能なのです。
しかし、残念ながら CSS4 に対応しているブラウザは現状ではありません。
今回は代替えとして、jQuery を使い同様の結果を実現してみます。

例えば、次のようなspan.show_offの親要素、つまり、2番目の li を指定したいとします。

<ul>
  <li>普通の表示</li>
  <li><span class="show_off">親要素を変更</span></li>
  <li>普通の表示</li>
</ul>

該当の li に jQuery でクラスを付与することで、別のスタイルを適用します。

<script>
jQuery(function($){
  $("ul li:has(.show_off)").addClass("accent");
});
</script>

実行後のソースには目的の2つめの li にaccentというクラスが追加されます。

<ul>
  <li>普通の表示</li>
  <li class="accent"><span class="show_off">親要素を変更</span></li>
  <li>普通の表示</li>
</ul>

あとはスタイルを指定します。

<style>
  .accent {color:cornflowerblue;}
</style>

こちらが出力結果です。

  • 普通の表示
  • 親要素を変更
  • 普通の表示

まあ、このようなケースでは通常はnth-childを使いますよね。
もうひとつ用例を紹介します。

oEmbed によるブログカード使用の際には URL を直書きしますが、デフォルトでは wpautop 関数により P タグが付与されるため、<p><iframe></iframe></p>のようになります。
Youtube 動画のエンベットや埋め込みでも同様ですね。
ソース上の美しさはさておき、動作自体に問題はありません。
ただ、ほとんどのケースで p タグには、マージンなどのスタイルが適用されているでしょう。
そのなかにiframeが配置されることで意図したレイアウトが行えない場合があります。

下記では本文を表示しているdiv.contentの p タグ内に配置したiframeの親要素の p タグにクラスを付与しています。

&lt;script&gt;
jQuery(function($){
  $(&quot;div.content p:has(iframe)&quot;).addClass(&quot;iframe-outer&quot;);
});
&lt;/script&gt;

出力結果は<p class="iframe-outer"><iframe></iframe></p>となり、この p タグのみ別のスタイルを適用できます。

&lt;style&gt;
.content p.iframe-outer {
  margin:0;
  padding:0;
}
&lt;/style&gt;

本来は親要素の p タグそのものを消して、必要に応じて iframe にスタイルを適用する方がよいですね(笑
下記で iframe の親タグ、つまり、p タグが除去されます。

&lt;script&gt;
jQuery(function($){
  $(&#039;div.content iframe&#039;).unwrap();
});
&lt;/script&gt;

直打ちの HTML ではじめからクラスなどを付与すれば済む話ですが、WordPress のように自動的にタグが追加される CMS では意外に使い道があるのではないでしょうか。

profile image

執筆:R3098

WEB サービス構築・監修が生業です。WordPress 関連では Aurora Heatmap などプラグイン開発も行っています。悩めるサイト運営者の無料相談受付けます!

コメントを残す

メールアドレスが公開されることはありません。 が付いている欄は必須項目です

このサイトは reCAPTCHA によって保護されており、Google のプライバシーポリシー および 利用規約 に適用されます。

reCaptcha の認証期間が終了しました。ページを再読み込みしてください。