JavaScript函數(shù)定義的常見注意事項小結(jié)
本文就javascript函數(shù)定義的常見問題進行了總結(jié)。包含了初學(xué)者常犯的錯誤。分享給大家供大家參考。具體總結(jié)如下:
1. 函數(shù)聲明的同時JS引擎還定義了一個與函數(shù)名同名的變量,我們在調(diào)用這個函數(shù)的時候?qū)嶋H上是在使用這個變量,且它可以在函數(shù)聲明之前調(diào)用,例如
foo(); //這里實際上是使用了一函數(shù)變量 function foo() { alert('hello'); }
2. 函數(shù)表達式,此時將匿名函數(shù)賦值給了一變量,此變量需在定義后使用,例如
foo(); //報錯,未定義 var foo = function() { alert('hello'); }
3. 函數(shù)表達式(with函數(shù)名),這種用法最好避免,此時非IE瀏覽器中該函數(shù)名只在內(nèi)部可用,例如
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構(gòu)造函數(shù)定義,這種方式效率低,每次執(zhí)行函數(shù)的時候,其函數(shù)體都會被解析一次。此外這樣聲明的函數(shù)是不會繼承當(dāng)前聲明位置的作用域,它默認只會擁有全局作用域,例如
function foo() { var bar = 'hello'; return Function('alert(bar)'); //報錯,全局變量bar未定義 } foo()();
相信本文所述對大家javascript WEB程序設(shè)計的學(xué)習(xí)有一定的借鑒價值。
相關(guān)文章
JavaScript實現(xiàn)清空(重置)文件類型INPUT元素值的方法
這篇文章主要介紹了JavaScript實現(xiàn)清空(重置)文件類型INPUT元素值的方法,結(jié)合實例形式分析了javascript清空input文本框的常用方法與實現(xiàn)技巧,需要的朋友可以參考下2016-11-11javascript獲取四位數(shù)字或者字母的隨機數(shù)
這篇文章主要介紹了javascript獲取四位數(shù)字或者字母的隨機數(shù),需要的朋友可以參考下2015-01-01