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

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

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

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

Q&A

解決済

2回答

543閲覧

Object.keys()でプロパティを列挙するコードについて

sanayaaan

総合スコア25

JavaScript

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

0グッド

0クリップ

投稿2021/02/14 08:45

下記のコードについて、不明点がありご質問させていただきます。

javascript

1'use strict'; 2{ 3 4const person = { 5 name: 'mico', 6 age: 25, 7}; 8 9const keys = Object.keys(person); 10keys.forEach(key =>{ 11 console.log(`Key: ${key} Value:${person[key]}`); 12}); 13}

console.log(`Key: ${key} Value:${person[key]}`);の部分で、
Key: ${key}でプロパティのキーが出力されるのはわかるのですが、Value:${person[key]でプロパティの値が出力されるのかがわからず進めずにいます。

どなたかわかりやすくご教示いただけませんでしょうか。
初歩的な質問で恐縮ですがどうぞよろしくお願いいたします。

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

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

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

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

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

m.ts10806

2021/02/14 08:59

質問は「なぜ」ではなく、「実行した結果出力されるのか否か」ですか? 実行したら分かる話をされているのかどうかを聞いています
sanayaaan

2021/02/14 09:07 編集

すみません、質問の文章が変でした。 「なぜ」Key: ${key}だとプロパティーのキーが表示され、Value:${person[key]だと値の方が表示されるのかがわかりません。 よろしければご教示いただけますと助かります。
m.ts10806

2021/02/14 09:14 編集

回答してます。ひとまず質問調整してください。
guest

回答2

0

node.jsとbrave,firefoxで実行してみました。
問題なさそうに思います。

出力結果

Key: name Value:micoKey: age Value:25```

投稿2021/02/14 08:57

phoepsilonix

総合スコア233

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

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

sanayaaan

2021/02/14 09:01

すみません、出力自体は実行されるのですが、なぜperson[key]で値が出力されるのかがわからず、、。質問が言葉足らずでした、失礼いたしました。
guest

0

ベストアンサー

const keys = Object.keys(person);で取得したpersonのkeyを回してるからです。
リファレンス確認すると分かりますが

Object.keys()

Object.keys() メソッドは、指定されたオブジェクトが持つプロパティの 名前の配列を、通常のループで取得するのと同じ順序で返します。

つまり、person['name']もしくはperson.nameのように直接keyを参照するのと理屈は同じです。
オブジェクトなので、key:value形式。keyにアクセスするとvalueが呼び出されます。

投稿2021/02/14 08:51

編集2021/02/14 09:22
m.ts10806

総合スコア80850

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

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

sanayaaan

2021/02/14 09:31

大変よく理解できました!! とても助かりました。ありがとうございました。
m.ts10806

2021/02/14 09:32

機能に疑問があるときは提示したようにリファレンス、ドキュメントを参照してください。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問