サイト内検索
Cocoonフォーラム
書き込みの前に以下の3点をご確認ください。
何を書き込んだら良いか分からない場合は、以下のテンプレートをコピペしてご利用ください。
不具合・カスタマイズ対象ページのURL:
相談内容:
不具合の発生手順:
解決のために試したこと:
※文字だけでは正しく伝わらない可能性があるため、スクショ画像の添付もお願いします。
※高速化設定をしている場合は無効にしてください。
環境情報:※↑こちらに「Cocoon設定 → テーマ情報」にある「環境情報」を貼り付けてください。
環境情報の取得方法はこちら。
→ https://wp-cocoon.com/theme-report/
高速化設定を無効にするにはこちら。
→ https://wp-cocoon.com/theme-trouble/
フォーラム利用ガイドリンク
- フォーラムガイドライン
- よくある質問と答え(FAQ)
- サポート対象外のケース
- 原因不明の不具合用トラブルシューティング
- トピックにHTMLを貼り付ける方法(推奨ツール:notepad.pw)
- 真っ白画面でのエラーメッセージの確認方法
- ブラウザ環境チェックツール
- Cocoonカスタマイズ依頼
フォーラム質問後、問題等が解決した場合は結果を書き込んでいただけると幸いです。同様の問題で調べている方には、結果が一番気になる部分となります。
このフォーラムには初心者の方も多く参加されています。質問に不慣れな方も安心して相談できるよう、できるだけ穏やかな言葉でご案内いただけますと幸いです。
通知
すべてクリア
トピックスターター 2026年6月9日 19:29
----------------------------------------------
テーマ名: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);
}
}
このトピックは3週間前 7回から大門未知子に変更されました
わいひら reacted
トピックスターター 2026年6月9日 20:02
●対策案
テストはしていません。
スクロールがミリ秒単位で一瞬止まった50ミリ秒後にタイマーを発動させ、コンテンツ位置を取得し直す。
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 );
} );
} )();
この投稿は3週間前ずつ大門未知子に変更されました
わいひら reacted
2026年6月9日 22:55
ご指摘とコードもいただきありがとうございます。
該当部分の修正をさせていただきました。
https://github.com/xserver-inc/cocoon/commit/c89c841d8ae5f7dfa4307545bbd7bfc3b6d03c0b
トピックスターター 2026年6月10日 21:38
●追記
上記は、[Cocoon設定]→[モバイル]→モバイルボタン「モバイルボタンを固定表示する」オフのとき問題となる。
●案
ヘッダーモバイルボタンの高さは、画面がリサイズされ、ナビゲーションラベルが折り返されるなどで変化する。
それまでは変化しない。
結果、ページロード、リサイズ時に、ヘッダーモバイルボタンの高さを取得する。
その分、containerの位置を変更する。
jQuery(function($) {
// 高さを更新する関数
function updateHeaderMenuHeight() {
var $menuButtons = $('.mobile-header-menu-buttons');
// 要素が存在する場合のみ実行
if ($menuButtons.length) {
var height = $menuButtons.outerHeight();
// html要素にCSS変数「--mobile-header-menu-height」を設定(単位: px)
$('html').css('--mobile-header-menu-height', height + 'px');
}
}
// 初回読み込み時に実行
updateHeaderMenuHeight();
// リサイズ時に実行(負荷軽減のためリサイズイベントを監視)
$(window).on('resize', function() {
updateHeaderMenuHeight();
});
});
:root {
--cocoon--mobile-header-menu-buttons--bottom: 0!important;
}
@media (600px < width <= 1023px) {
.body:has(.mobile-header-menu-buttons) .container{
margin-top:var(--mobile-header-menu-height);
}
}
@media (width <=600px) {
.body:has(.mobile-header-menu-buttons) .container{
margin-top:calc(var(--mobile-header-menu-height) - var(--wp-admin--admin-bar--height));
}
}
この投稿は3週間前ずつ大門未知子に変更されました
トピックスターター 2026年6月10日 21:46
●上記コードについて追記
ヘッダーモバイルボタンの位置を求めようとすると、スクロールにより例えばキャッチフレーズおりあとにヘッダーモバイルボタンが表示された場合、正しく求めることができない。
このため、高さを求め、ヘッダーモバイルボタン分の余白をあらかじめ設ける。
ヘッダーモバイルボタンより先に例えばキャッチフレーズが画面内に表示された場合、margin-topが見えるが、遅れ表示されるため、軽微なことと判断する。
この投稿は3週間前 2回ずつ大門未知子に変更されました
トピックスターター 2026年6月10日 22:33
●誤記
.body.scrollable-mobile-buttons:has(.mobile-header-menu-buttons) .container{
style.css、javascript.jsを2.9.3.1に戻し、上記コードを変更しているJSに追加?
※変更したJSは--cocoon--header-container--position-offsetの追加は、Gutenbergで.is-position-stickyとした時の考慮。
トピックスターター 2026年6月11日 12:58
●追記
javascript.jsを修正し、ヘッダーモバイルボタンの高さを監視し、CSS変数に退避。
元々のヘッダーモバイルボタンの監視は、.is-position-stickyとした時、ヘッダー部下にするための考慮。
https://notepad.pw/share/u781nery9
以下のCSSを追加。
@media (600px < width <= 1023px) {
.body.scrollable-mobile-buttons:has(.mobile-header-menu-buttons) .container{
margin-top:var(--mobile-header-menu-height);
}
}
@media (width <=600px) {
.body.scrollable-mobile-buttons:has(.mobile-header-menu-buttons) .container{
margin-top:calc(var(--mobile-header-menu-height) - var(--wp-admin--admin-bar--height));
}
}
わいひら reacted
2026年6月11日 22:05
ありがとうございます。
GitHubのファイルを修正しておきました。
トピックスターター 2026年6月11日 23:02
----------------------------------------------
テーマ名:Cocoon
バージョン:2.9.3.3
カテゴリー数:18
タグ数:123
投稿数:1753
固定ページ数:12
ユーザー数:1
----------------------------------------------
対策されていることを確認しました。
本件をクローズとします。
わいひら reacted
2026年6月12日 19:54
ご確認いただきありがとうございます。
問題の解決に至った場合には、トピック冒頭の「解決済み」をクリックしていただけますと幸いです。
また、有用な回答があった場合は返信右下にある「いいね!」もご活用ください。回答者の励みになります。
(CC BY-ND 2.1)準じていれば(リンクを貼っていただければ)転載も自由です。カスタマイズ記事を書く際にコード等をコピペ利用していただいて構いません。
フォーラムの使い方がよくわからない場合は、テストトピックで自由にテストしていただいて構いません。
最近の書き込みはこちら。
詳細なカスタマイズ依頼をするならこちら。








