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

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

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

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

Q&A

解決済

2回答

2146閲覧

この記法の意味は?

sutara79

総合スコア26

JavaScript

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

0グッド

0クリップ

投稿2017/05/06 11:41

下記のページにこのようなコードがあります。
https://github.com/tmpvar/jsdom

javascript

1const { JSDOM } = jsdom;

この、変数名を{ }で囲むのはどういう記法なのでしょうか?
ためしに下記のようなコードを書いて、ブラウザでJavaScriptとして、コマンドラインでNode.jsとして実行してみましたが、どちらも結果は同じでした。
barundefinedとなります。

javascript

1const foo = 'FOO'; 2const { bar } = 'BAR'; 3console.log(foo); // FOO 4console.log(bar); // undefined

しかし、上のリンクのnpmパッケージの場合はundefinedとはなりません。
この記法はnpm独特のものなのでしょうか?

javascript

1var { JSDOM } = require("jsdom"); 2console.log(JSDOM); // [Function: JSDOM]

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

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

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

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

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

guest

回答2

0

オブジェクトの分割代入(Destructuring assignment)です。ES2015で追加された比較的新しい記法ですね。

このように変更すればお使いのブラウザにもよりますが動くと思いますよ。

diff

1const foo = 'FOO'; 2- const { bar } = 'BAR'; 3+ const { bar } = { foo: 'foo', bar: 'BAR' }; 4console.log(foo); // FOO 5console.log(bar); // BAR

この例で言えば右辺の { foo: 'foo', bar: 'BAR' } にあるbarというプロパティの値を定数barに代入するという意味になります。

投稿2017/05/06 11:58

t_tonchim

総合スコア96

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

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

sutara79

2017/05/06 12:01

全く知りませんでした…。ES2015の記法だったんですね。 ありがとうございました。
guest

0

ベストアンサー

JavaScript

1var obj = {"foo": "foo's value", "bar": "bar's value"}; 2var { foo } = obj; 3console.log(foo); // => "foo's value"

みたいなことが出来ます。

投稿2017/05/06 11:52

otn

総合スコア84555

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

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

sutara79

2017/05/06 11:57

ありがとうございました。 そういう意味だったんですね。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問