Cocoonフォーラム

サイト内検索
書き込みの前に以下の3点をご確認ください。
  1. 1つのトピックにつき1つの質問を書き込んでください
  2. 不具合・カスタマイズ対象ページのURLを提示高速化を無効にしてください
  3. 該当部分のキャプチャ・環境情報とともに書き込んでいただけると助かります

何を書き込んだら良いか分からない場合は、以下のテンプレートをコピペしてご利用ください。

不具合・カスタマイズ対象ページのURL:

相談内容:

不具合の発生手順:

解決のために試したこと:

※文字だけでは正しく伝わらない可能性があるため、スクショ画像の添付もお願いします。
※高速化設定をしている場合は無効にしてください。
環境情報:

※↑こちらに「Cocoon設定 → テーマ情報」にある「環境情報」を貼り付けてください。

環境情報の取得方法はこちら。
https://wp-cocoon.com/theme-report/
高速化設定を無効にするにはこちら。
https://wp-cocoon.com/theme-trouble/

フォーラム利用ガイドリンク

  1. フォーラムガイドライン
  2. よくある質問と答え(FAQ)
  3. サポート対象外のケース
  4. 原因不明の不具合用トラブルシューティング
  5. トピックにHTMLを貼り付ける方法(推奨ツール:notepad.pw
  6. 真っ白画面でのエラーメッセージの確認方法
  7. ブラウザ環境チェックツール
  8. Cocoonカスタマイズ依頼

フォーラム質問後、問題等が解決した場合は結果を書き込んでいただけると幸いです。同様の問題で調べている方には、結果が一番気になる部分となります。

このフォーラムには初心者の方も多く参加されています。質問に不慣れな方も安心して相談できるよう、できるだけ穏やかな言葉でご案内いただけますと幸いです。

昨今のCSS仕様に対応した :has(...
 
通知
すべてクリア

[解決済] 昨今のCSS仕様に対応した :has() によるタブ切り替えCSSについて

1 投稿
1 ユーザー
0 Reactions
102 表示
大門未知子
(@chu-ya)
Illustrious Member Registered
結合: 4年前
投稿: 4489
トピックスターター  

本件は紹介のみでクローズとします。

----------------------------------------------
テーマ名:Cocoon
バージョン:2.9.2.12
カテゴリー数:18
タグ数:124
投稿数:1749
固定ページ数:12
ユーザー数:1
----------------------------------------------

従来のタブ切り替えCSSでは、「~」(後続兄弟結合子)を使用し、input[type="radio"] の :checked 状態を基準に後続要素を制御している。

1. #index-tab-1 がアクティブ(:checked)の場合、後続兄弟要素 .index-tab-buttons 内の .index-tab-button[for=index-tab-1](対応するタブボタン)をアクティブ表示にしている。

https://github.com/xserver-inc/cocoon/blob/20811dc3c9bd02045be1f225ba56899e729cf60b/style.css#L10618-L10626

2. #index-tab-1 がアクティブ(:checked)の場合、同じ親要素内に存在する後続兄弟要素 .tab-cont.tb1 を表示している。

https://github.com/xserver-inc/cocoon/blob/20811dc3c9bd02045be1f225ba56899e729cf60b/style.css#L10649-L10655


一方、:has() を使用した場合は、親要素 .index-tab-wrap が #index-tab-1:checked の状態を保持しているかを基準にスタイルを適用できる。

.index-tab-wrap:has(#index-tab-1:checked) .index-tab-button[for="index-tab-1"],
.index-tab-wrap:has(#index-tab-2:checked) .index-tab-button[for="index-tab-2"],
.index-tab-wrap:has(#index-tab-3:checked) .index-tab-button[for="index-tab-3"],
.index-tab-wrap:has(#index-tab-4:checked) .index-tab-button[for="index-tab-4"] {
  background: none var(--cocoon-tab-label-active-color);
  border: 1px solid var(--cocoon-tab-label-active-color);
  color: var(--cocoon-white-color);
  font-weight: 700;
}

.index-tab-wrap:has(#index-tab-1:checked) .tab-cont.tb1,
.index-tab-wrap:has(#index-tab-2:checked) .tab-cont.tb2,
.index-tab-wrap:has(#index-tab-3:checked) .tab-cont.tb3,
.index-tab-wrap:has(#index-tab-4:checked) .tab-cont.tb4 {
  display: block;
  animation: tab-index-show 0.3s ease-in;
}

:has() を使用することで、従来の「~」による後続兄弟要素への依存を減らし、親要素を基準とした状態管理が可能になる。


このトピックは3週間前 4回から大門未知子に変更されました

   
引用
共有:

問題の解決に至った場合には、トピック冒頭の「解決済み」をクリックしていただけますと幸いです。

また、有用な回答があった場合は返信右下にある「いいね!」もご活用ください。回答者の励みになります。

「いいね!」機能はフォーラム登録者のみが利用できる機能です。

CC BY-ND 2.1)準じていれば(リンクを貼っていただければ)転載も自由です。カスタマイズ記事を書く際にコード等をコピペ利用していただいて構いません。

フォーラムの使い方がよくわからない場合は、テストトピックで自由にテストしていただいて構いません。

最近の書き込みはこちら。

詳細なカスタマイズ依頼をするならこちら。

タイトルとURLをコピーしました