javascriptと作業する場合、開発者はしばしば2つの構成要素に遭遇します:関数式と宣言。機能は類似していますが、ブラウザによる処理と実行コンテキスト内での読み込み動作は異なります。次の構文を使用して定義されています。 }
宣言された関数
宣言は、関数キーワードを使用して明示的に宣言される関数と名付けられています。それらの構文は次のとおりです。 }
var foo = function() { return 5; }
これらの構造の重要な違いは、荷重動作にあります。関数宣言は、実行コンテキストの最上部に掲げられ、コードが実行される前に利用可能です。これにより、宣言される前に呼び出すことができ、宣言の前であっても、現在のスコープ内のどこにでもアクセスできます。
関数式は、通訳者がそのコードラインに到達した場合にのみロードされます。これは、宣言される前に関数式を呼び出そうとすると、エラーが発生することを意味します。関数式は、宣言された範囲内でのみアクセスできます。 //これによりエラーが発生します var foo = function(){return 5; }この例では、宣言の前に関数式式FOOは利用できないため、
function foo() { return 5; }
という名前の関数式
は、以下のシンソックスを使用して機能しますが、
を使用して機能します。 5; }この構文は歴史的にsafariのエラーを起こしやすいものでしたが、最新のブラウザーで予想されるように機能します。関数宣言はスコープ全体ですぐに利用できますが、関数式は必要なときにのみロードされ、コードベース内でより制御されたアクセスが可能になります。正しいコードの実行を確保し、潜在的なランタイムエラーを回避するには、それらの区別を理解することが重要です。
免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。
Copyright© 2022 湘ICP备2022001581号-3