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

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

HTMLを縮小化すると「再利用可能ブロ...
 
共有:
通知
すべてクリア

[解決済] HTMLを縮小化すると「再利用可能ブロック」が破損します

10 投稿
3 ユーザー
5 Reactions
2,165 表示
 wp5
(@wp5)
Active Member Registered
結合: 5年前
投稿: 6
トピックスターター  

素晴らしいテーマを使わせていただいてありがとうございます。

Cocoonの高速化設定で「HTMLを縮小化する」を有効にし、ブロックエディタ使用時に 再利用可能ブロックを呼び出すと、登録済みのブロックが破損します。

恐らく、HTMLの縮小化によってブロックエディタ用のコメントアウト?部分が消えてしまうために、すべてクラシックブロックに変換され、ブロックの種類によっては再利用可能ブロックのプレビューと同時にエディタがクラッシュします。

クラッシュ時のエラーは以下のとおりです。

TypeError: Cannot read property 'setContent' of null
at t.value ( https://mydomain.net/wp-includes/js/dist/block-library.min.js?ver=2.4.6:23:41795)
at qi ( https://mydomain.net/wp-includes/js/dist/vendor/react-dom.min.js?ver=16.8.4:130:296)
at ui ( https://mydomain.net/wp-includes/js/dist/vendor/react-dom.min.js?ver=16.8.4:133:320)
at https://mydomain.net/wp-includes/js/dist/vendor/react-dom.min.js?ver=16.8.4:158:377
at unstable_runWithPriority ( https://mydomain.net/wp-includes/js/dist/vendor/react.min.js?ver=16.8.4:27:36)
at Vc ( https://mydomain.net/wp-includes/js/dist/vendor/react-dom.min.js?ver=16.8.4:158:360)
at Sc ( https://mydomain.net/wp-includes/js/dist/vendor/react-dom.min.js?ver=16.8.4:158:144)
at Z ( https://mydomain.net/wp-includes/js/dist/vendor/react-dom.min.js?ver=16.8.4:156:492)
at Zg ( https://mydomain.net/wp-includes/js/dist/vendor/react-dom.min.js?ver=16.8.4:159:8)
at Xe ( https://mydomain.net/wp-includes/js/dist/vendor/react-dom.min.js?ver=16.8.4:23:322)

(注)ドメイン部分は置き換えています。

フロントエンドの表示には影響はないのですが、投稿時に再利用可能ブロックをよく使うので困っています。ご対応いただけると幸いです。

※WordPressおよびCocoonのバージョンは投稿時で最新のものです。

 


   
わいひら
(@yhira)
Illustrious Memberサイト Admin
結合: 7年前
投稿: 17394
 

一応、修正してみました。
僕の環境では、これで改善しました。
------------------------------------------------
https://github.com/yhira/cocoon
最新ファイルをダウンロードする場合は、上記ページのダウンロードボタンからzipファイルをダウンロードしてください。

FTPでのアップデート方法はこちら。
https://wp-cocoon.com/ftp-update/
------------------------------------------------
ただ、既に縮小化されてしまった「再利用ブロック」は、元には戻らないようです。


   
ろこ
(@lococo)
Prominent Member Registered
結合: 7年前
投稿: 830
 

トピックの内容からは少し外れるのですが、HTMLの縮小化開始はafter_setup_themeフックからでないとだめなのでしょうか?

サイト表示時のHTMLは読み込むテンプレートファイル群(header.php~footer.php)なので、テンプレートファイル一式を縮小するのでもよさそうな気はするのですが。


   
edit and わいひら reacted
わいひら
(@yhira)
Illustrious Memberサイト Admin
結合: 7年前
投稿: 17394
 

ダメということはないです。
after_setup_themeは、作成当初ググったサンプルコードを使って今もそのままになっている感じです。
ただ、いろいろ使用していると思いのほか不都合な部分が多いのに気づき、今回のようにかなり除外が必要になってしまいました。

サイト表示時のHTMLは読み込むテンプレートファイル群(header.php~footer.php)なので、テンプレートファイル一式を縮小するのでもよさそうな気はするのですが

可能ならそれでも良いかと思います。
ただそうなると、今のところどの部分で読み込んで縮小化し、どの部分で出力するのかイメージが湧いていません。

get_template_partの先のlocate_templateとかload_templateあたりも見てみたのですが、めぼしいフィルターフックが見つかりませんでした。
https://core.trac.wordpress.org/browser/tags/5.2.2/src/wp-includes/template.php
何か良い方法をご存知でしょうか?


   
ろこ
(@lococo)
Prominent Member Registered
結合: 7年前
投稿: 830
 

今のところどの部分で読み込んで縮小化し、どの部分で出力するのかイメージが湧いていません。

正しいのかどうかは分かりませんが、コードを見た感じだとおそらく出力する箇所は今のままで問題はないと思います。

https://github.com/yhira/cocoon/blob/master/lib/page-speed-up/minify-html.php#L115

理由は、WordPress本体でもob_end_flushの処理を同じ箇所で行っているからです。
(wp_ob_end_flush_allの処理を見るに、ob_end_flushの処理を用意しなくても勝手にやってくれるっぽいですね。)

https://core.trac.wordpress.org/browser/tags/5.2.2/src/wp-includes/default-filters.php#L352

 

そうなると、開始の箇所はheader.phpを読み込む直前でよさそうなので、get_header関数のアクションフック'get_header'でどうでしょうか?

飽くまでもコード上でのことなので、実際に書いてみると何か不具合があるかもしれませんが、いけるのであればis_minify_page関数のような条件に悩まされずに済みそうです。


   
edit and わいひら reacted
 wp5
(@wp5)
Active Member Registered
結合: 5年前
投稿: 6
トピックスターター  

お返事ありがとうございます。

githubから最新版をダウンロードしてインストールしましたが、改善しませんでした。自分の環境のせいかと思い、以下を実施しましたが、いずれも改善しませんでした。

  • 全プラグインの無効化
  • 子テーマから親テーマに切り替え、HTML縮小を有効にする
  • local環境にWordPressを新規インストールし、githubから最新版のCocoonをインストール(プラグインは一つもインストールしていない状態、Cocoonの設定はHTML縮小以外初期設定のまま)

各状況では、念のためブラウザキャッシュもクリアしています。

何か他に要因があるのでしょうか。


   
わいひら
(@yhira)
Illustrious Memberサイト Admin
結合: 7年前
投稿: 17394
 

そうなると、開始の箇所はheader.phpを読み込む直前でよさそうなので、get_header関数のアクションフック'get_header'でどうでしょうか?

まさにこれが最適解っぽいです。
get_headerにフックを入れ替えて、いろいろ動作確認してみましたが、機能追加して以来抱えていた悩みがすべて解決しました。
is_minify_page関数自体、僕の悩みを具現化したようなコードなんですが、すべて不要になりました。
当然、管理ページでは動作しないし(iframe除く)、フィードページでも動作しない、robots.txtでも動作しないし、解析用のカウントでも動作しない。
それでいて、通常ページでは、しっかりと1回だけ読み込んでくれます。
ここをこんな綺麗な形で、解決することができて、嬉しいです。
ありがとうございます!


   
わいひら
(@yhira)
Illustrious Memberサイト Admin
結合: 7年前
投稿: 17394
 

githubから最新版をダウンロードしてインストールしましたが、改善しませんでした。自分の環境のせいかと思い、以下を実施しましたが、いずれも改善しませんでした。

1つ上の返信でも書いたように修正したので、一度以下のファイルでアップデートして試していただけますでしょうか。
------------------------------------------------
https://github.com/yhira/cocoon
最新ファイルをダウンロードする場合は、上記ページのダウンロードボタンからzipファイルをダウンロードしてください。

FTPでのアップデート方法はこちら。
https://wp-cocoon.com/ftp-update/
------------------------------------------------

僕の環境をでは、以前に登録したものも問題なく表示されるようになりました。


   
 wp5
(@wp5)
Active Member Registered
結合: 5年前
投稿: 6
トピックスターター  

修正最新版をインストールしたところ、問題解決しました!お忙しい中、素早いご対応ありがとうございます。

わいひら様、ロコ様に感謝です ? !


   
わいひら reacted
わいひら
(@yhira)
Illustrious Memberサイト Admin
結合: 7年前
投稿: 17394
 

動作確認ありがとうございます!
今回僕は何もやってないです。
ロコさんの修正案が素晴らしすぎました。


   
共有:

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

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

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

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

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

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

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

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