[解決済み] カーリーブレイスの配置によって結果が異なるのはなぜですか?
2022-05-08 02:06:16
質問
以下のコードスニペットは、なぜ この記事 中括弧の配置を1つ変えただけで、異なる結果が得られるのでしょうか?
冒頭の中括弧が
{
が改行されている場合。
test()
が返されます。
undefined
と表示され、アラートに "no - it broke: undefined" が表示されます。
function test()
{
return
{ /* <--- curly brace on new line */
javascript: "fantastic"
};
}
var r = test();
try {
alert(r.javascript); // does this work...?
} catch (e) {
alert('no - it broke: ' + typeof r);
}
と同じ行にブレースがある場合。
return
,
test()
はオブジェクトを返し、"fantastic" はアラートされます。
function test()
{
return { /* <---- curly brace on same line */
javascript: "fantastic"
};
}
var r = test();
try {
alert(r.javascript); // does this work...?
} catch (e) {
alert('no - it broke: ' + typeof r);
}
解決方法は?
それがJavaScriptの落とし穴のひとつ、セミコロンの自動挿入です。セミコロンで終わっていない、しかし文の終わりである可能性がある行は自動的に終了されるので、最初の例は事実上次のようになります。
function test()
{
return; // <- notice the inserted semicolon
{
javascript: "fantastic"
};
}
参照 Douglas CrockfordのJSスタイルガイド で、セミコロンの挿入について触れています。
2つ目の例では、(中括弧で囲まれた)オブジェクトを、プロパティ
javascript
とその値である
"fantastic"
ということで、実質的にはこれと同じです。
function test() {
var myObject = new Object();
myObject.javascript = "fantastic";
return myObject;
}
関連
-
jsを使った簡単な照明スイッチのコード
-
Vue+ElementUIによる大規模なフォームの処理例
-
Vueの一般的な組み込みディレクティブの説明
-
[解決済み】awaitは非同期関数でのみ有効です。
-
[解決済み】JavaScriptでインラインIF文の書き方は?
-
[解決済み】「.addEventListener is not a function」なぜこのエラーが発生するのか?
-
nullのプロパティinnerHTMLを読み取れません エラーメッセージ
-
OSSアップロードエラーを解決する: net::ERR_SSL_PROTOCOL_ERROR
-
[解決済み] なぜリストの初期化(中括弧を使用)が他の方法より優れているのですか?
-
[解決済み】Javascriptのイテラブルを配列に変換する
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
親子コンポーネント通信を解決する3つのVueスロット
-
Vueの要素ツリーコントロールに破線を追加する説明
-
元のイベントが実行されなかった後に要素を追加するためのjQueryソリューション
-
Javascript Bootstrapのグリッドシステム、ナビゲーションバー、ローテーションの説明
-
vue ディレクティブ v-html と v-text
-
[解決済み】Uncaught SyntaxError: JSONの位置0に予期しないトークンuがあります。
-
[解決済み】GETできない / Nodejsエラー
-
[解決済み】 Uncaught TypeError : undefined のプロパティ 'replace' を読み取れない In Grid
-
[解決済み】ReactJSでエラー発生 Uncaught TypeError: Super expression は null か関数でなければならず、undefined ではありません。
-
Uncaught TypeError: null のプロパティ 'offsetHeight' を読み取れませんでした。