您好,登錄后才能下訂單哦!
這篇文章主要講解了JavaScript自定義函數(shù)的用法,內(nèi)容清晰明了,對此有興趣的小伙伴可以學(xué)習(xí)一下,相信大家閱讀完之后會有幫助。
一、定義方法:在Javascript中必須用function關(guān)鍵字
function funcName(arg1,arg2...) { statements; return "變量值"; //返回值可以根據(jù)函數(shù)的需要 }
函數(shù)名是函數(shù)自身的一個引用。此種方式創(chuàng)立的函數(shù)引用是獨立存在的,無法刪除。
1、調(diào)用函數(shù):函數(shù)名(參數(shù)列表)。
傳遞的參數(shù)不必與函數(shù)定義的參數(shù)個數(shù)一致,并且可以設(shè)定函數(shù)參數(shù)的默認(rèn)值。
function example(a,b){ var a = arguments[0] ? arguments[0] : 1;//設(shè)置參數(shù)a的默認(rèn)值為 var b = arguments[1] ? arguments[1] : 2;//設(shè)置參數(shù)b的默認(rèn)值為2 return a+b; } alert(example()); //輸出3
其他方法:設(shè)置默認(rèn)參數(shù)方式
2、嵌套函數(shù):在JS中,函數(shù)的定義中還可以再次定義新的函數(shù)
function say() { function add(x,y) { return (x+y); } alert(add(2,3)); } say(); //輸出5
內(nèi)嵌函數(shù)add()只能在嵌套它的函數(shù)(say())中調(diào)用,而不能再外部調(diào)用。
3、條件函數(shù):
var b = false; if(b) { function ex1() { alert(1); } ex1(); } else { function ex2() { alert(0); } ex2(); }
輸出0,將b的值改為TRUE,則輸出1,不演示。條件函數(shù)的花括號不具有范圍限制,即可以在花括號外訪問函數(shù)。
二 、函數(shù)的特殊條用方式:網(wǎng)頁中的所有方法可以看做全局對象window對象的方法
function add(x,y) { return x+y; } //1 alert(window.add(2,3)); //2 alert(window['add'](2,3));
以上結(jié)果均是5
三、函數(shù)表達(dá)式定義函數(shù):匿名函數(shù)
1、定義方式:var fucName = function(arg1,arg2,...){statements;}
var add = function (x,y) { return x+y; } alert(add(2,3));//輸出為5
其中,add是該函數(shù)的唯一引用,當(dāng)add=null,該函數(shù)便不能再調(diào)用。
2、匿名自執(zhí)行函數(shù):
(function(x,y) { alert(x + y) ; })(2,3); //立即自動執(zhí)行,結(jié)果為5
3、匿名函數(shù)的用途
2.1 用于一次調(diào)用后就丟棄的函數(shù)
2.2 向prototype屬性附加函數(shù)以實現(xiàn)對象方法的定義
四、使用Function定義函數(shù):
在JS中,F(xiàn)unction為核心類的一種,而其他方式定義的函數(shù)也均作為對象對待,因為在JS中的OOP中,不存在類的概念,這是JS與Java、C#等語言的區(qū)別。
var add = new Function(“函數(shù)參數(shù)”,"函數(shù)體"); add為函數(shù)名,即函數(shù)的一個引用。
var add = new Function('x','y',"return x+y"); alert(add(2,3));
上述的結(jié)果為5.
五、閉包函數(shù):當(dāng)一個函數(shù)不位于它所處環(huán)境(變量的作用范圍)被調(diào)用,仍可使用本地變量(脫離了變量的作用范圍仍可使用該變量),這是閉包函數(shù)的顯著特征。
5.1 作為值從函數(shù)返回的函數(shù)是閉包函數(shù)
function B() { var temp="abc"; function A() { alert("閉包函數(shù)處理本地變量temp = "+temp); } return A; } var a = B(); a();
運行結(jié)果:(本地變量是函數(shù)內(nèi)聲明的變量)
5.2 利用變量的作用范圍形成閉包函數(shù)
var F; function B() { var temp="abc"; F=function () { alert("利用變量范圍形成閉包函數(shù)處理本地變量temp = "+temp); } } B(); F();
運行結(jié)果
看完上述內(nèi)容,是不是對JavaScript自定義函數(shù)的用法有進(jìn)一步的了解,如果還想學(xué)習(xí)更多內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。