質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

Q&A

解決済

1回答

3355閲覧

WordPressで改行つきの本文を JSON.parse したい

bananna

総合スコア11

WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

0グッド

0クリップ

投稿2019/07/03 13:49

WordPressの本文をjsonで出力するときに、改行コードが邪魔でJSON.parseができません。

どうすべきかご教授頂けましたら幸いです。

###現状
ローカルストレージに記事データ(IDと本文)がjsonで入っています。
###目的
それを取得するときに下記のようにJSON.parseしたいです。

console.log( localStorage.getItem(name) ); // 【図1】の出力 postData = JSON.parse( localStorage.getItem(name) );

###問題
しかし、コンソールを見ると【図1】のように本文の改行があるため、JSON.parseがエラーになってしまうという状況です。

【図1】
イメージ説明

###試したこと
PHPで本文を取得するときはget_the_content()を使っており、その場合【図1】のような出力になります。

これは\n\nが出力されているのだと思ったので、nl2br( get_the_content() )として取得しました。するとコンソールは【図2】のようになり、やはり改行が削除しきれない状況です。

【図2】
イメージ説明

###質問
どうすれば
・改行があるままでJSON.parseできるでしょうか?
・またはJSON.parseするために改行を適切に処理できるでしょうか?

すみませんが、宜しくお願い致します。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

kei344

2019/07/03 13:54

(質問文は編集できます)get_the_content周辺の出力コードも提示されたほうが良いです。
bananna

2019/07/03 15:17 編集

失礼致しました。後ほど編集しておきます。
guest

回答1

0

ベストアンサー

js

1JSON.stringify({"all":[{"id":291,"content":`かめがすきです。 2 3甲羅の模様がたまりません。`}]}); 4 5/* 6{"all":[{"id":291,"content":"かめがすきです。\n\n甲羅の模様がたまりません。"}]} 7*/

という結果でしたので、JSON文字列として\nで表現すればいいと思います。
PHPから直接localStorageに値をセットすることはできないと思うので、JavaScriptを通す必要があると思います。JavaScriptのコードで\nという文字列を表現すると\nになると思いますので、それをPHPで表現すればいいのではないでしょうか。

投稿2019/07/03 15:00

Lhankor_Mhy

総合スコア36115

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

bananna

2019/07/03 15:58 編集

こんばんは。「JSON文字列として\nで表現する」といいますと、どのような内容になりますでしょうか?初心者質問ですみません。
Lhankor_Mhy

2019/07/03 15:32

回答にも書きましたが、「JSON文字列として\nで表現する」には「JavaScriptのコードで\nになる」ということです。なので、PHPでそれを表現すればいいかと思います。 おそらく改行を\\nに置換してechoすれば(raw文字列があればそちらでも)いいのだと思いますが、すみません、私のPHP知識は初心者レベルなので、詳細は他の方のご回答をお待ちいただきたいと思います。
bananna

2019/07/03 16:00 編集

下記でエラーは消え、無事 JSON.parse できました。 $content = get_the_content(); $content = preg_replace('/\n|\r|\r\n/', '<br>', $content ); ただしなぜか改行が二倍の数に増えてしまうので、引き続き検討してまいります。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問