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

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

共有:
通知
すべてクリア

[解決済] CocoonとWordPress本体のLazy Load機能に関して

13 投稿
2 ユーザー
9 Likes
3,789 表示
ろこ
(@lococo)
Prominent Member Registered
結合: 5年前
投稿: 830
Topic starter  

ブラウザのサポート状況からまだしばらくはCocoonのLazy Load機能も残しておくのだと思いますが、高速化のLazy Load設定とWordPress本体のLazy Load機能を一致させる(もしくはWordPress本体の方はCocoon設定がオフのままでも動作する等の補足説明を加えるなど)のが分かりやすいです。

https://wp-cocoon.com/community/postid/36581/


   
わいひら
(@yhira)
Illustrious Member Admin
結合: 5年前
投稿: 14161
 

主要なものだと問題となりそうなものは、IEはいいとしてSafariだけっぽいですね。
https://caniuse.com/#feat=loading-lazy-attr

個人的にはWordPressにLazy Loadが実装されたら、機能を廃止してしまってもいいのかなと思います。


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

個人的にはWordPressにLazy Loadが実装されたら、機能を廃止してしまってもいいのかなと思います。

CocoonのLazy Load機能は廃止するとのことで分かりました。

 

ちなみに、CocoonのLazy Load機能はminify-html.phpでページ全体に対応している一方、WordPress本体のLazy Load機能の対応範囲は

  • 記事本文内の画像
  • テキストウィジェット内の画像
  • get_the_post_thumbnail(the_post_thumbnail)で出力する画像

に加え、Cocoonではカテゴリー・タグページのコンテンツとアピールエリア内になります。

上記に当てはまらない、例えば

  • おすすめカード
  • ナビカード
  • ボックスメニュー

などは対応していないようですが、問題ないでしょうか?


   
mirutana reacted
わいひら
(@yhira)
Illustrious Member Admin
結合: 5年前
投稿: 14161
 
投稿者:: @lococo

ちなみに、CocoonのLazy Load機能はminify-html.phpでページ全体に対応している一方、WordPress本体のLazy Load機能の対応範囲は

  • 記事本文内の画像
  • テキストウィジェット内の画像
  • get_the_post_thumbnail(the_post_thumbnail)で出力する画像

に加え、Cocoonではカテゴリー・タグページのコンテンツとアピールエリア内になります。

この動作については確認していませんでした。
確かに当サイトでPageSpeed Insightsを試してみた感じでは、以下がLazy Loadに対応していないようです(添付画像)。

投稿者:: @lococo

 

  • おすすめカード
  • ナビカード
  • ボックスメニュー

 

冒頭でロコさんが書かれたような対応にさせてもらおうかと思います。


   
わいひら
(@yhira)
Illustrious Member Admin
結合: 5年前
投稿: 14161
 

今試してみたのですが、「WordPressのLazy Load」と「CocoonのLazy Load」双方を有効にした場合は、CocoonのLazy Loadの方が優先されてしまうみたいですね…。
せっかくWordPressのLazy Loadは優秀なのに、ここら辺はどうしたものか。


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

Lazy Loadのブラウザ対応状況から冒頭では併用等を提案しましたが、最終的にはCocoonのLazy Load機能は削除し、WordPress本体の機能に統一する形が望ましいので、#post-38161で説明したように

  1. 画像タグを生成する関数get_the_post_thumbnailを使用する。
  2. コンテンツ内の画像タグを置換するフック用関数wp_filter_content_tags(5.4以前はwp_make_content_images_responsive)をHTML出力前に使用する。

など、対応できてない実装箇所を修正するのがWordPress本体の関数を流用できてシンプルに対応できるかと思います。


   
わいひら
(@yhira)
Illustrious Member Admin
結合: 5年前
投稿: 14161
 

基本的なサムネイル画像のみ(本文以外)にCocoonのLazy Loadが反映されるように修正してみました。
https://github.com/yhira/cocoon
WordPressのLazy Loadの仕様上、外部リンクの画像はLazy Load対応はされていない(多分サイズが取得できないから?)ようですが、ここはそのままでいこうかなと思います。


   
わいひら
(@yhira)
Illustrious Member Admin
結合: 5年前
投稿: 14161
 

設定画面。


   
わいひら
(@yhira)
Illustrious Member Admin
結合: 5年前
投稿: 14161
 

申し訳ないです。
昨日GitHubにプッシュするのを忘れていました ? 


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

修正ありがとうございます。
確認しました。

 

関数post_lazy_load_thumbnail_htmlとフックが重複しているように見えます。

加えて、ブログカードと投稿下ページ送りナビのNO IMAGE画像が対応していない(関数get_no_image_post_thumbnail_tagを通していない)ようですが、何か問題がありましたでしょうか?


   
わいひら
(@yhira)
Illustrious Member Admin
結合: 5年前
投稿: 14161
 
投稿者:: @lococo

関数post_lazy_load_thumbnail_htmlとフックが重複しているように見えます。

コピペかなにかをミスったんだと思います。削除しておきました。

投稿者:: @lococo

加えて、ブログカードと投稿下ページ送りナビのNO IMAGE画像が対応していない(関数get_no_image_post_thumbnail_tagを通していない)ようですが、何か問題がありましたでしょうか?

いえ、単なる修正漏れです。
修正コードを追加しておきました。


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

Cocoonのカテゴリー・タグページコンテンツすでに対応している(#post-38161)ので、

https://github.com/yhira/cocoon/blob/master/lib/settings.php#L323

の1行は必要ありません。

関数wp_make_content_images_responsiveが5.5から非推奨になり、代わりに関数wp_filter_content_tagsが使用されるようになりましたが、wp_filter_content_tagsは5.4以前には存在しない関数なのでエラーが出ると思います。

 

私が確認した範囲では、以上の修正で問題はなさそうです。


   
わいひら
(@yhira)
Illustrious Member Admin
結合: 5年前
投稿: 14161
 

ご確認いただきありがとうございます。
該当部分は削除しておきます。


   
共有:

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

wpForoの解決済みリンク

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

wpForoのいいねリンク

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

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

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

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

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

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