JavaScript で「var」を省略すると、予期しないグローバル変数やエラーが発生するのはなぜですか?

Patricia Arquette
リリース: 2024-11-03 09:25:29
オリジナル
858 人が閲覧しました

Why Does Omitting

グローバル変数宣言の危険

JavaScript の領域では、開発者は「暗黙的グローバルの恐怖」として知られる落とし穴について長い間警告されてきました。これは、変数が「var」キーワードなしで宣言されている場合に発生します。

一般的な考えに反して、「var」を省略してもパフォーマンスに重大な利点はありません。代わりに、グローバル変数が作成され、意図しない変数の漏洩や、ページ上の他のスクリプトとの潜在的な競合が発生する可能性があります。

この問題を説明するには、次の関数を考えてみましょう:

<code class="javascript">function foo() {
    variable1 = 5;
    varaible2 = 6;
    return variable1 + variable2;
}</code>
ログイン後にコピー

「varaible2」の宣言のタイプミスにより、関数は期待値 11 ではなく NaN を返します。さらに、「varaible2」という名前のグローバル変数が誤って作成され、関数の外部からアクセスできます:

<code class="javascript">console.log(foo());     // NaN
console.log(varaible2); // 6?!?!?!</code>
ログイン後にコピー

この予期しない動作により、コード内で混乱を招き、デバッグが困難なエラーが発生する可能性があります。これらの落とし穴を回避するには、関数の内部と外部の両方で変数を宣言するときに常に「var」キーワードを使用することが重要です。

以上がJavaScript で「var」を省略すると、予期しないグローバル変数やエラーが発生するのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート