サイト内検索
Cocoonフォーラム

書き込みの前に以下の3点をご確認ください。
何を書き込んだら良いか分からない場合は、以下のテンプレートをコピペしてご利用ください。
不具合・カスタマイズ対象ページのURL:
相談内容:
不具合の発生手順:
解決のために試したこと:
※文字だけでは正しく伝わらない可能性があるため、スクショ画像の添付もお願いします。
※高速化設定をしている場合は無効にしてください。
環境情報:※↑こちらに「Cocoon設定 → テーマ情報」にある「環境情報」を貼り付けてください。
環境情報の取得方法はこちら。
→ https://wp-cocoon.com/theme-report/
高速化設定を無効にするにはこちら。
→ https://wp-cocoon.com/theme-trouble/
フォーラム利用ガイドリンク
- フォーラムガイドライン
- よくある質問と答え(FAQ)
- サポート対象外のケース
- 原因不明の不具合用トラブルシューティング
- トピックにHTMLを貼り付ける方法(推奨ツール:notepad.pw)
- 真っ白画面でのエラーメッセージの確認方法
- ブラウザ環境チェックツール
- Cocoonカスタマイズ依頼
フォーラム質問後、問題等が解決した場合は結果を書き込んでいただけると幸いです。同様の問題で調べている方には、結果が一番気になる部分となります。
トピックスターター 2025年5月8日 01:54
以下の対応をして思ったことがあり。
https://wp-cocoon.com/community/postid/85052/
試しにテンプレート化してみましたが、単に置き換えるだけでなく、関数全体を見直した方が望ましいと思え。
以前、話したテンプレートの第三パラメータをサポートしてます。
今回のようにレイアウト変更をするなら、関数を子テーマにコピーし修正するのが望ましいと思え。
このため、要望でもないので、雑談として記録に残します。
----------------------------------------------
テーマ名:Cocoon
バージョン:2.8.5.5
カテゴリー数:18
タグ数:122
ユーザー数:1
----------------------------------------------
●目的
新着記事・ナビカード、人気記事のHTML部をテンプレート化する。
テンプレートフックにより、カードごとの処理が可能になる。
先の質問の対応してdo_shortcode_tagフックを用いた場合、新着記事全体が対象となる。
このため、preg_replaceでは複雑になり、またDOMDocumentで処理するならPHPでなくJSの方が楽となり。
そこで、カードをテンプレート化すると、HTML対象が小さくなるので、preg_replaceも複雑にならずに済み。
add_filter('cocoon_part__tmp/widget-entry-card', function($content, $args) { if ($args['prefix'] == WIDGET_NEW_ENTRY_CARD_PREFIX) { $html = get_the_nolink_category(get_the_ID(), 1) $content = preg_replace( '/(<div class="new-entry-card-date[^"]*widget-entry-card-date[^"]*">.*?)(<\/div>)/is', '$1' . $html . '$2', $content ); } return $content; });
人気記事も同様なので省略します。
●tmp/widget-entry-card.php
関数get_widget_entry_card_link_tagのHTMLの部分を抜き出しテンプレート化。
https://notepad.pw/share/pifau1Z46F877RMsFTa0
●html-forms.php
関数get_widget_entry_card_link_tagのHTML部分をテンプレート呼び出しに変更。
https://notepad.pw/share/aA0v46Cm6hOnJiHkUWsG
●utils.php
関数cocoon_template_partに第三パラメータを追加し、get_template_partに渡す。
cocoon_part__{$slug}フックに第二パラメータを追加し$argsを渡す。
このトピックは15時間前から大門未知子に変更されました
問題の解決に至った場合には、トピック冒頭の「解決済み」をクリックしていただけますと幸いです。
また、有用な回答があった場合は返信右下にある「いいね!」もご活用ください。回答者の励みになります。
(CC BY-ND 2.1)準じていれば(リンクを貼っていただければ)転載も自由です。カスタマイズ記事を書く際にコード等をコピペ利用していただいて構いません。
フォーラムの使い方がよくわからない場合は、テストトピックで自由にテストしていただいて構いません。
最近の書き込みはこちら。
詳細なカスタマイズ依頼をするならこちら。