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

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

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

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

WordPress

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

PHP

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

JavaScript

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

Q&A

解決済

3回答

381閲覧

PHPからデータベースを取得してscriptタグで表示がしたいです。

退会済みユーザー

退会済みユーザー

総合スコア0

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

WordPress

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

PHP

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

JavaScript

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

0グッド

1クリップ

投稿2021/05/27 09:24

編集2021/05/27 09:29

前提・実現したいこと

wpdbを利用し、PHPでデータベースからテーブルを取得した上で、配列に入れました
scriptに持ってくることまではできましたが、objectと表示されてしまいます。

web表示状態
[object Object],[object Object],[object Object],[object Object]

発生している問題・エラーメッセージ

html

1document.write(id); 2web結果 3[object Object],[object Object],[object Object],[object Object] 4 5console.log(id); 6結果 7consoleには表示される 8(4) [{…}, {…}, {…}, {…}] 90: {m_id: "m_A", m_sta: "1", m_date: "05-28"} 101: {m_id: "m_B", m_sta: "1", m_date: "05-28"} 112: {m_id: "m_C", m_sta: "0", m_date: "05-28"} 123: 13m_date: "05-28" 14m_id: "m_bulid" 15m_sta: "0" 16__proto__: Object 17length: 4 18__proto__: Array(0)

該当のソースコード

html

1 <?php 2 3 global $wpdb; 4 5 $result = $wpdb->get_results('select * from wp_row'); 6 7 8 $sampleJson = json_encode($result); 9 ?> 10 11<script> 12 13 var id = <?php echo $sampleJson?>; 14 15 console.log(id); 16 17 document.write(id); 18

試したこと

ここに問題に対して試したことを記載してください。

補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

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

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

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

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

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

m.ts10806

2021/05/27 09:26

コードはマークダウンのcode機能にてご提示ください
退会済みユーザー

退会済みユーザー

2021/05/27 09:26

WordPressのことなら、質問タグにWordPressをつけてくださいね。
退会済みユーザー

退会済みユーザー

2021/05/27 09:30

修正いたしました!ありがとうございます。
guest

回答3

0

ベストアンサー

PHPでjson_encodeされた結果の文字列はJavaScriptにとってはオブジェクトだからです。
writeで書き出すにしろtextContentに出力するにしろ、中身を一つずつ取り出すか、stringifyで文字列に変換するかどちらかで対応必要です。
用途に合わせてください。

投稿2021/05/27 09:29

m.ts10806

総合スコア80854

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

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

退会済みユーザー

退会済みユーザー

2021/05/27 09:34

後ほどデータベースと合わせてtrueだったらデータベースの結果だすみたいなを作りたいのですが テーブルを全部だしてからが良いと感じました。 JSON.stringify()こちらは文字列に変換するとのことですが document.write(Json.stringify(id)); これでは難しかったです
m.ts10806

2021/05/27 09:58

「難しかった」のが何が起きた結果そう仰っているか不明です。 そもそもdocument.write()は非推奨なので別の手段を利用してください。
guest

0

html

1document.write(JSON.stringify(id));

こちらにて

html

1[{"m_id":"m_BBS","m_sta":"1","m_date":"05-28"},{"m_id":"m_cal","m_sta":"1","m_date":"05-28"},{"m_id":"m_work","m_sta":"0","m_date":"05-28"},{"m_id":"m_bulid","m_sta":"0","m_date":"05-28"}]

結果が出るようになりました。

投稿2021/05/27 09:44

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

0

関数リファレンス/wpdb Class - WordPress Codex 日本語版

この関数はクエリの結果全体を配列として返します。この配列の各要素はクエリ結果の各行と対応します。

ってことなので、それに応じた処理をjs上で書くしかないのでは?
foreachループを回して、m_idメンバーにアクセスするとか。
関数リファレンスや、wpdb Classの解説記事を探してみてはいかがでしょうか。

投稿2021/05/27 09:31

編集2021/05/27 09:32
退会済みユーザー

退会済みユーザー

総合スコア0

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

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

退会済みユーザー

退会済みユーザー

2021/05/27 09:38

後ほどデータベースと合わせてm_idと表の文字列が一致したらm_staの結果をだす みたいなを作りたいのですが テーブルを全部だしてからが良いと感じました foreachで回して配列に入れるってことでしょうか?
退会済みユーザー

退会済みユーザー

2021/05/27 09:43

ん~、10件20件ならそれでもいいかもしれないけど、100件1000件10000万件とか増えたら待たされるよ? データ抽出はSQL文でデータベースに任せるのがセオリーなので、悪いことは言わないのでSELECT文にWHERE句を補って使うデータだけに絞るようにするべきです。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問