ホームページ >ウェブフロントエンド >jsチュートリアル >改行は JavaScript の戻りステートメントに影響を与える可能性がありますか?
改行が JavaScript の return ステートメントに与える影響
return ステートメントとオブジェクトの間に改行が発生すると、JavaScript 関数で予期しない動作が発生する可能性があります戻ろうとしているのです。この問題は、JavaScript の自動セミコロン挿入 (ASI) メカニズムが原因で発生します。
コード例:
次のコードを検討してください。
<code class="javascript">function foo1() { return {msg: "hello1"}; } function foo2() { return {msg: "hello2"}; }</code>
When実行すると、このコードは次のように出力されます:
foo1 = {"msg":"hello1"} foo2 = undefined
説明:
これらの関数の違いは、foo2 では {msg: 'hello2'} が配置されることです。新しい行。 JavaScript はセミコロンが省略された場合でもセミコロンを想定する傾向があり、改行がステートメントの区切り文字として解釈されます。結果として、foo2 は、意図したオブジェクトではなく、未定義を返します。
解決策:
この問題を回避するには、オブジェクトを同じ状態に保つようにコードを変更できます。行を return ステートメントとして使用します。あるいは、グループ化演算子を使用して、オブジェクトを関数内の式として明示的に定義することもできます。
<code class="javascript">function foo2() { return ({msg: "hello2"}); }</code>
この変更により、foo2 は目的のオブジェクトを正しく返します。
考慮事項:
見た目の美しさのためにグループ化演算子を使用するかどうかは、個人的な好みの問題です。特に大きなコード ブロックを扱う場合、可読性が向上します。ただし、グループ化演算子はグループ内の最後の式のみを評価することに注意することが重要です。
以上が改行は JavaScript の戻りステートメントに影響を与える可能性がありますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。