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

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

ブログカードの英文が連結されてしまいま...
 
共有:
通知
すべてクリア

[解決済] ブログカードの英文が連結されてしまいます。

12 投稿
4 ユーザー
10 Reactions
560 表示
(@merlion1006)
Active Member Registered
結合: 1年前
投稿: 6
Topic starter  

お世話になります。

大変初心者です。

Polylangというプラグインを導入し、ウィジェットで言語スイッチャーをしています。

ブログカードに英文が表示される際、文章にブランクが入らず、ピリオドまでone wordになっています。

例えば、MynameisMerlion.Thankyouforyoursupportinadvance. という感じです。

ブログカードをクリックし、そのページに到達すると、My name is Merlion. Thank you for your support in advance. のように問題なく表示されます。

以前使用していた(といってもそれほど多く投稿していなかったのですが。)Themeではブログカードがなかったようでしたので、Cocoonさんのthemeに変更させていただきました。

ブログカードでも単語と単語の間にスペースが入るような設定をご教示いただければ幸いでございます。

どうぞ宜しくお願い致します。


   
chu-ya
(@chu-ya)
Famed Member Registered
結合: 3年前
投稿: 2895
 

●原因
以下で「カスタムHTML」ブロックが先頭にある場合、og:description、エントリーカードスニペットに、意図しない半角シペースが入り、これを対策した。

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

その際、半角スペースを削除とした。
今回のような英文の場合、単語間の半角スペースが削除され、連続した文字となってしまった。

https://github.com/xserver-inc/cocoon/blob/ac7a44ceb81dc4a6da8af5ebfe8b5c099e67c642/functions.php#L66


   
chu-ya
(@chu-ya)
Famed Member Registered
結合: 3年前
投稿: 2895
 

カスタムHTML中のインデントした半角スペースなのか、文中の半角スペースなのか、区別する必要があり。
良い案が思いつかず。

●対策案

minify_htmlを用い、一旦、$contentから、本文中以外の、余分な半角スペースを除去する。
前述の追加したコードを削除する。


●余談

wp_trim_words任せでできるか?と思いしたが、文末に半角スペース(0x20)が入り。
ただ、タグ除去や、三点リーダー追加を任せても良いかと思いました。


   
わいひら reacted
(@akira)
Famed Member Registered
結合: 7年前
投稿: 1657
 

考えや好みで異なる部分だと思いますが、スニペットの抜粋関数(get_content_excerpt)に半角スペースやタブ除去が含まれていなかった不具合修正 は私の好みではありません。

このような HTML が先頭にある場合…

<aside class="widget my_categories">
  <ul>
    <li class="cat-item">
      <a href="#">キヤノン</a>
    </li>
    <li class="cat-item">
      <a href="#">ニコン</a>
    </li>
    <li class="cat-item">
      <a href="#">ソニー</a>
    </li>
  </ul>
</aside>

抜粋はこうなります。「キヤノン」や「ニコン」などが単語ではなく 1 つの文章に見えます。「キヤノンニ」「コンソニー」って何?と思ってしまいます。

キヤノンニコンソニー

1 つ 1 つが単語として見えるようにスペースで区切るのが私の好みです。

キヤノン ニコン ソニー

また、抜粋の中に少々半角スペースがあっても私は気にしません。

これを踏まえて私であれば、以前変更したget_content_excerpt() の部分 を…

$content = preg_replace('/\s/','',$content); //半角スペースやタブ、改行を取り除く

このように変更します。全角スペースをどうするかは迷ったため、全角スペースを半角スペースに変換する部分はコメントアウトしています。

// $content = preg_replace('/ /', ' ', $content); // 全角スペースを半角スペースに変換する
$content = preg_replace('/\s+/', ' ', $content); // 連続するスペースを1つにまとめる
$content = trim($content); // 先頭と末尾から空白文字を取り除く

これでは人によっては不十分なんだろうか。少なくとも英文の半角スペースが消えることはありません。


wp_trim_words() だけを使うのは、おそらくわいひらさんのお好みではない気がします。ショートコードを取り除けないです。

This post was modified 1年前 3回 by Akira

   
わいひら and chu-ya reacted
chu-ya
(@chu-ya)
Famed Member Registered
結合: 3年前
投稿: 2895
 

ありがとうございます。

投稿者:: @akira

1 つ 1 つが単語として見えるようにスペースで区切るのが私の好みです。

言われるように、行毎に半角スペースが入るので、スニペットを見た時、分かり易いと思います。(図参照)

投稿者:: @akira

wp_trim_words() だけを使う

そうです、ショートコードは除去されません。
三点リーダー部分と、文字数分の切り出しの部分が、置き替えれるかと思いました。

 


   
わいひら reacted
(@akira)
Famed Member Registered
結合: 7年前
投稿: 1657
 

>> Merlion1006 さん

親テーマに何かしらの修正はされると思います。ただ、いつ修正されるか分かりません。それまでお待ちになることはできないと思いますので、このような対応をされてはいかがでしょうか?

まずは、以下のいずれかの方法で親テーマの functions.php を開きます。

  • FTP ソフトを使う
  • サーバーのファイルマネージャーを使う
  • WordPress 管理画面 > 外観 > テーマファイルエディターと進み、「編集するテーマを選択」で「Cocoon」を選び「選択」をクリックします。そして、テーマのための関数(functions.php) をクリックします。添付画像の部分です。

親テーマの functions.php を開いた後は、66 行目の以下の部分を探します。

$content = preg_replace('/\s/','',$content); //半角スペースやタブ、改行を取り除く

この 66 行目をこのように変更します。

$content = str_replace(PHP_EOL, '', $content); //改行を取り除く

※ WordPress 管理画面 > 外観 > テーマファイルエディターをお使いになる場合は、コードを変更後に「ファイルを更新」をクリックします。

このコードの変更により、以前の Cocoon の動作に戻ります。これで英文の半角は削除されないです。

This post was modified 1年前 by Akira

   
わいひら reacted
(@merlion1006)
Active Member Registered
結合: 1年前
投稿: 6
Topic starter  

chu-yaさま、Akiraさま、

アイディアをご教示いただきありがとうございます!

WordPress 管理画面 > 外観 > テーマファイルエディターで、functions.phpの66行目をご指定いただいた構文にreplaceしましたところ、半角スペースが復活しブログカードの英文が読めるようになりました。

丁寧に教えていただきましてありがとうございました。感謝致します。

Merlion1006


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

投稿者:: @merlion1006

ブログカードに英文が表示される際、文章にブランクが入らず、ピリオドまでone wordになっています。

例えば、MynameisMerlion.Thankyouforyoursupportinadvance. という感じです。

僕の想定ミスです。申し訳ありません。
Akiraさんも案で修正したものをGitHubにアップしておきました。
近いうちにアップデートもしたいと思います。
------------------------------------------------
https://github.com/xserver-inc/cocoon
開発中の最新ファイルをダウンロードする場合は、上記ページのダウンロードボタンからzipファイルをダウンロードしてください。

WordPressでの手動アップデート方法はこちら
https://wp-cocoon.com/manual-update-of-cocoon-theme/
------------------------------------------------


   
Merlion1006 reacted
(@akira)
Famed Member Registered
結合: 7年前
投稿: 1657
 

>> わいひらさん

申し訳ないです。改めて見ると trim() では不十分かもしれません。

このように書きましたが…

// $content = preg_replace('/ /', ' ', $content); // 全角スペースを半角スペースに変換する
$content = preg_replace('/\s+/', ' ', $content); // 連続するスペースを1つにまとめる
$content = trim($content); // 先頭と末尾から空白文字を取り除く

このように変更するのがいいかもしれません。

$content = preg_replace('/\s+/', ' ', $content); // 連続するスペースを1つにまとめる
$content = preg_replace('/\A[\x00\s]++|[\x00\s]++\z/u', '', $content); // 先頭と末尾から空白文字を取り除く

文中の全角スペースを変更するのは意図しない動作になるケースがあると思います。ただ、先頭と末尾には全角であっても半角であってもスペースはいらないように思えます。先頭と末尾に全角スペースが必要なケースを思い付かないです。

trim() では全角スペースが残るのが気になったため、【PHP】マルチバイト(全角スペース等)対応のtrim処理の 別のコード1 を参考にしました。

This post was modified 1年前 by Akira

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

ありがとうございます。
冒頭と末尾の全角スペースのことまでは考えてませんでした。
修正しておきました。
https://github.com/xserver-inc/cocoon/commit/e6a15fd912553ca879fed1012a2074f59d91912d
文章全体(本文)の前後に全角スペースを入れるとしたら、段落の一文字目に全角スペースを入れて字下げすることくらいしか思いつかないですね。
ただいずれにせよ抜粋文となれば必要ないですね。


   
Akira reacted
(@akira)
Famed Member Registered
結合: 7年前
投稿: 1657
 

余計なお手間を取らせてしまい申し訳ないです。変更を確認しました。試した限りでは、動作も問題ないです。


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

ご確認ありがとうございます!


   
共有:

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

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

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

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

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

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

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

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