1.函數宣告
function sum1(n1,n2){ return n1+n2; };
2.函數表達式,又叫函數字面量
var sum2=function(n1,n2){ return n1+n2; };
兩者的區別:解析器會先讀取函數聲明,並使其在執行任何程式碼之前可以存取;而函數表達式則必須等到解析器執行到它所在的程式碼行才會真正被解釋執行。
自執行函數嚴格來說也叫函數表達式,它主要用於創建一個新的作用域,在此作用域內聲明的變量,不會和其它作用域內的變量衝突或混淆,大多是以匿名函數方式存在,且立即自動執行。
(function(n1,n2){ console.log (n1+n2) })(1,3);//4
另外幾個自執行函數:
//可用来传参 (function(x,y){ console.log(x+y); })(2,3); //带返回值 var sum=(function(x,y){ return x+y; })(2,3); console.log(sum); ~function(){ var name='~' console.log(name); }(); !function(){ var name='!' console.log(name); }(); ;(function(){ var name=';' console.log(name); })(); -function(){ var name='-' console.log(name); }(); //逗号运算符 1,function(){ var name=','; console.log(name); }(); //异或 1^function(){ var name='^'; console.log(name); }(); //比较运算符 1>function(){ var name='>'; console.log(name); }(); ~+-!(function(){ var name='~+-!'; console.log(name); })(); ~!(function(){ var name='~!'; console.log(name); })(); (function(){ var name='call'; console.log(name); }).call(); (function(){ var name='apply'; console.log(name); }).apply();
3.函數建構法,參數必須加引號
var sum3=new Function('n1','n2','return n1+n2'); console.log(sum3(2,3));//5
從技術角度講,這是一個函數表達式。一般不建議用這種方法定義函數,因為這種語法會導致解析兩次程式碼(第一次是解析常規ECMAScript程式碼,第二次是解析傳入建構函數中的字串),進而影響效能。
var name='haoxl'; function fun(){ var name='lili'; return new Function('return name');//不能获取局部变量 } console.log(fun()());//haoxl
Function()構造函數每次執行時都會解析函數主體,並建立一個新的函數對象,所以當在一個循環或頻繁執行的函數中呼叫Function ()構造函數效率是非常低的。而函數字面量卻不是每次遇到都會重新編譯的,用Function()構造函數創建一個函數時並不遵循典型的作用域,它一直把它當作是頂級函數來執行。
【相關教學推薦】