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

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

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

JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

JavaScript

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

Q&A

解決済

2回答

2357閲覧

デベロッパーツールのJsonデータ読み込み、出力したらundefinedが出た

退会済みユーザー

退会済みユーザー

総合スコア0

JSON

JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

JavaScript

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

0グッド

0クリップ

投稿2020/10/04 05:56

編集2020/10/04 06:21

jsonを扱ったjavascriptの挙動を確認するために以下のコードをchromeのデベロッパーツールで試しました

javascript

1const json =`{"id":1,"name":"js-primer"}`; 2const obj =JSON.parse(json); 3console.log(obj.id); 4console.log(obj.name); 5

コンソールで試した結果が
1 VM41:3
js-primer VM41:4
undefined
1とjs-primerはわかるのですが、
この二つのVM以下とundefinedは何を意味しているのでしょうか?(undefined自体が未定義の値ということは知っています)
プログラミング初学者なので初歩的な質問かもしれませんがよろしくご回答お願いします。

googleでは__”コンソール VM”,"コンソール json VM"__と調べてみましたがしっくりくるものが出てきませんでした。

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

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

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

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

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

guest

回答2

0

ベストアンサー

VM の部分は、その出力がされたコードの箇所へのリンクになっています。
クリックすると実行したコードでconsoleへ出力した箇所がわかるようになっています。

undefined は実行した最後のステートメント(今回はconsole.log(obj.name);)のリターン?が undefined ということです。

JavaScript

1const json =`{"id":1,"name":"js-primer"}`; 2const obj =JSON.parse(json); 3console.log(obj.id); 4console.log(obj.name); 5json //ここを追加

とかやると、json 変数の内容が出力されます。
行頭にマーク(Chrome なら"<"っぽいやつ、Firefox なら矢印)がある行がリターンになります。

Text

1 1 VM277:3 2 js-primer VM277:4 3< "{"id":1,"name":"js-primer"}"

複数行をまとめてコピペするんじゃなくて、1行ごとに実行してみるとわかりやすいんじゃないでしょうか。

投稿2020/10/04 11:11

draq

総合スコア2577

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

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

退会済みユーザー

退会済みユーザー

2020/10/04 22:47

解答ありがとうございます。最初にvmをクリックして確かめようとしたのですが、出てきた画面がごちゃついて訳が分からなかったので読むのをやめてしまいました…。今見てみると確かに画面右にあるコードの行数とVM右の数字二つ目と一致しますね。 早速一行ずつコンソールに打ってみたのですが、そもそも戻り値が指定されていない場合は常にundefinedが出力されるのですね。知らなかったです。勉強になりました。
guest

0

最小限にまで削除して実行しました。

HTML

1<html> 2<head> 3 <meta charset="UTF-8"> 4 <script type="text/javascript"> 5 const json =`{"id":1,"name":"js-primer"}`; 6 const obj =JSON.parse(json); 7 console.log(obj.id); 8 console.log(obj.name); 9 </script> 10</head> 11<body> 12</body> 13</html>

IE11、Firefox、chrome(windows64bit版)
すべて正常に動きました。

投稿2020/10/04 10:51

kuma_kuma_

総合スコア2506

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

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

退会済みユーザー

退会済みユーザー

2020/10/04 22:51

回答ありがとうございます。自分でもコピペして確かめてみました。ファイルから読み込むととくに問題なく動くことがわかりました。しかし今回知りたかったのはコンソール上での動きだったので、申し訳ありませんが直接質問の答えになっているdraqさんの回答をベストアンサーにさせていただきます。
kuma_kuma_

2020/10/04 23:13 編集

この回答はファイルから実行する分には問題が発生しませんという事を伝えるものですから。 問題ありあません。 ただ確認済みの場合質問欄にその事を記入して下さい。
退会済みユーザー

退会済みユーザー

2020/10/04 23:47

ごめんなさい。言葉が足りませんでした。確認したのはkuma_kumaさんから回答をいただいたのを受けての反応でしたので、最初には確認しておりません。その場合でも質問を編集して質問欄に確認をした旨を書くべきでしょうか?
kuma_kuma_

2020/10/05 01:00

そうですね、後から試されたのなら追記してほしいです。 そうすれば回答者が同じことを確認する必要はありませんので。
退会済みユーザー

退会済みユーザー

2020/10/05 23:37 編集

申し訳ありませんでした。 以後の質問では確認済みのことはすべて追記するようにいたします。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問