teratail header banner
teratail header banner
質問するログイン新規登録

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

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

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

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

Q&A

解決済

2回答

356閲覧

JavaScriptのObject.keysメソッドを使ってプロパティ名ではなくプロパティ値を取り出す方法について教えてください

echizeyayota

総合スコア106

JavaScript

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

0グッド

0クリップ

投稿2023/09/26 12:45

0

0

下記の質問についてご存知の方がいらっしゃいましたらご教示を願います。

【質問の主旨】

下記のオブジェクト変数languagesから各プロパティ値の、”English”, “Japanese”, “”French” を取り出したい場合、Object.keysメソッド使って取り出せることが分かりました。

const languages = { en: 'English', ja: 'Japanese', fr: 'French', }; console.log(Object.keys(languages).map(key => languages[key])); // Expected output: Array ["English", "Japanese", "French"]

ただmap関数の中の返り値をlanguages[key] として角かっこの中にkeyを与えると、プロパティ名ではなくプロパティ値の方が返ってくるのでしょうか?

もしmdnのドキュメントそのような内容のことが書いていれば、そのページのURLも教えていただければ幸いです。私が確認した限りでは、こちらの公式ドキュメントにはそれらしきことが書いていないような気がします。

以上、よろしくお願い申し上げます。

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

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

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

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

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

guest

回答2

0

ベストアンサー

ただmap関数の中の返り値をlanguages[key] として角かっこの中にkeyを与えると、プロパティ名ではなくプロパティ値の方が返ってくるのでしょうか?

考え方がおかしいです。

Object.keys(languages)で、['en', 'ja', 'fr']というキーだけの配列が返ります。Object.keysの役割はここまでで、それ以降はこの結果の配列をmapに通してキーで値を引いているだけです。


本題ではありませんが、単に値だけ得たいのなら、Object.valuesを使うことで一発で片付きます。

投稿2023/09/26 13:38

編集2023/09/26 13:41
maisumakun

総合スコア146653

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

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

echizeyayota

2023/09/28 09:14

> それ以降はこの結果の配列をmapに通してキーで値を引いているだけです。 ご説明ありがとうございます。 了解しました。今後ともどうぞよろしくお願いします。
guest

0

maisumakun さんのご回答の通りですが、補足しますと、

ブラウザーの互換性 | Object.keys() - JavaScript | MDN
ブラウザーの互換性 | Object.values() - JavaScript | MDN

対応バージョンナンバーをご覧になるとわかると思いますが、Object.values()が登場した時期がObject.keys()よりかなり遅いのです。
要するに、Object.keys()はあるけど、Object.values()がない、という時期が(5年ほど前に2,3年ぐらい?)ありました。

ですので、echizeyayota さんがご提示されたコードはその時期に書かれたか、または古いブラウザ(IEなど)に対応するために書かれたものだと思います。

投稿2023/09/27 05:18

Lhankor_Mhy

総合スコア37463

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

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

echizeyayota

2023/09/28 09:15

補足の説明ありがとうございます。 Object.values() メソッドは初めて知りました。こちらも活用いたします。 今後ともどうぞよろしくお願いします。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.30%

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

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

質問する

関連した質問