本文就javascript函數定義的常見問題進行了總結。包含了初學者常犯的錯誤。分享給大家供大家參考。具體總結如下:
1. 函數宣告的同時JS引擎也定義了一個與函數名稱同名的變量,我們在調用這個函數的時候實際上是在使用這個變量,並且它可以在函數聲明之前調用,例如
foo(); //这里实际上是使用了一函数变量 function foo() { alert('hello'); }
2. 函數表達式,此時匿名函數賦值給了一變量,此變數需在定義後使用,例如
foo(); //报错,未定义 var foo = function() { alert('hello'); }
3. 函數表達式(with函數名),這種用法最好避免,此時非IE瀏覽器中該函數名稱只在內部可用,例如
bar(5); //报错,未定义 var bar = function foo(n) { if (n == 1) return 1; else return n * foo(n - 1); } foo(5); //非IE报错,未定义 bar(5); //正确
4. 用Function建構函式定義,這種方式效率低,每次執行函式的時候,其函式體都會被解析一次。另外這樣宣告的函數是不會繼承目前宣告位置的作用域,它預設只會擁有全域作用域,例如
function foo() { var bar = 'hello'; return Function('alert(bar)'); //报错,全局变量bar未定义 } foo()();
相信本文所述對大家javascript WEB程式設計的學習有一定的借鏡價值。