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カスタマイズ依頼

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

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

ヘッダーモバイルボタンに下のコンテンツ...
 
通知
すべてクリア

ヘッダーモバイルボタンに下のコンテンツが隠れてしまい表示されない

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

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

●現象

[ユーザー]→[プロフィール]→「サイトを見るときにツールバーを表示する」オンの場合、
600px<画面幅≦1023pxのときキャッチフレーズが隠れてしまう。

また、メニューのナビゲーションラベルが長い場合、折り返し表示され、ヘッダーモバイルボタンの高さが大きくなる。
このため、コンテンツが隠れてしまう。
(ヘッダーモバイルボタンの高さは50pxとは限らない)


●補足

動的にコンテンツ位置を求めており。
以下で対応可能と思ったが、ヘッダーモバイルボタンが遅れて表示される場合、0pxとなり正しく動作しない

@media (width <= 1023px) {
	.container {
		margin-top: var(--cocoon--header-container--position-offset);
	}
}

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

   
引用
大門未知子
(@chu-ya)
Illustrious Member Registered
結合: 4年前
投稿: 4504
トピックスターター  

●対策案

テストはしていません。

スクロールがミリ秒単位で一瞬止まった50ミリ秒後にタイマーを発動させ、コンテンツ位置を取得し直す。

https://github.com/xserver-inc/cocoon/blob/e95529a7de4e8b51cb12ee6d69bf8d89ff13d237/javascript.js#L286-L333

notepadでエラーとなるので、以下にコードを添付します。

// ヘッダーの位置オフセットを更新
( function () {
  // スクロール時のタイマー変数をここで確実に宣言
  var scrollTimer = null;

  function updateHeaderOffset() {
    const header = document.getElementById( 'header-container' );

    let offset = 0;

    if ( header && header.classList.contains( 'fixed-header' ) ) {
      offset = header.offsetHeight;
    }

    // .mobile-header-menu-buttonsのtopを取得して処理
    const mobileHeaderMenuButtons = document.querySelector(
      '.mobile-header-menu-buttons'
    );
    if ( mobileHeaderMenuButtons ) {
      const computedStyle = window.getComputedStyle( mobileHeaderMenuButtons );
      const topValue = parseFloat( computedStyle.top );

      if ( topValue >= 0 ) {
        // topが0以上の場合は、その要素の高さを反映
        offset += mobileHeaderMenuButtons.offsetHeight;
      } else {
        // topが0未満の場合は、0pxとして扱う(offsetは変更しない)
        // 必要に応じて、ここで追加の処理を行う
      }
    }

    document.documentElement.style.setProperty(
      '--cocoon--header-container--position-offset',
      offset + 'px'
    );
  }

  document.addEventListener( 'DOMContentLoaded', updateHeaderOffset );

  // ブラウザサイズ変更時に更新(リサイズ処理が完了してから実行するため、少し遅延させる)
  let resizeTimer;
  window.addEventListener( 'resize', function () {
    clearTimeout( resizeTimer );
    resizeTimer = setTimeout( function () {
      updateHeaderOffset();
    }, 100 );
  } );

  // スクロール時にも更新
  window.addEventListener( 'scroll', function () {
    // リアルタイムで一度計算
    updateHeaderOffset();

    // タイマーをクリアして、スクロール停止から50ms後に最終計算
    clearTimeout( scrollTimer );
    scrollTimer = setTimeout( function () {
      updateHeaderOffset();
    }, 50 );
  } );
} )();

この投稿は1時間前ずつ大門未知子に変更されました

   
返信引用
共有:

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

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

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

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

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

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

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

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