JavaScript パラメータ受け渡しメカニズム: 値によるか参照によるか?
JavaScript は、多くのプログラミング言語と同様に、その動作についてしばしば疑問を引き起こします。パラメータ受け渡しメカニズム。この場合、人気のある JavaScript 参考書の特定の例により、読者は言語でのパラメーター受け渡しの性質について熟考することになりました。
質問:
混乱は以下から生じます。 my という名前のパラメータが関数内で未定義のように見えますが、後で再定義される例です。関数のパラメーター リストに明確な参照がないため、読者は、JavaScript がパラメーターを参照によって渡すのか、それとも値によって渡すのか疑問に思うでしょう。さらに、内部関数から関数が返されないという事実により、潜在的なクロージャ動作の理解がさらに複雑になります。
答え:
JavaScript のパラメータ受け渡し動作を正しく理解するにはプリミティブ値とオブジェクトを区別することが重要です。
プリミティブ vsオブジェクト:
提供された例では、my パラメータは定義されたオブジェクトへの参照です。関数の後半で。この参照を渡すことにより、関数内で行われた変更 (l プロパティと w プロパティの追加など) により、元のオブジェクトが更新されます。ただし、(置換の例で見られるように) 関数内で my 参照自体を再割り当てしようとしても、呼び出し元の参照には影響しません。
Closure:
この例では、他のネストされた関数から関数が返されないため、クロージャーの動作は示されません。クロージャは、別の関数内で定義された関数が返された場合にのみ発生し、外側の関数が戻った後でも外側のスコープから変数にアクセスできるようになります。
以上がJavaScript パラメータは値渡しですか、それとも参照渡しですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。