javascript是一門用于網(wǎng)頁開發(fā)的編程語言,其最為重要的特點(diǎn)就是實(shí)現(xiàn)了交互式的網(wǎng)頁效果。想要實(shí)現(xiàn)復(fù)雜的交互式頁面,javascript中的函數(shù)就起到了至關(guān)重要的作用。函數(shù)是一組封裝了一定功能代碼的實(shí)體,在javascript中我們可以通過定義一個函數(shù)來使其在不同的地方多次調(diào)用,大大簡化代碼的編寫。
javascript中用來定義函數(shù)的方式分為兩種:
第一種方式是函數(shù)聲明式,這種方式最為常見。它直接聲明了一個函數(shù)的名稱和函數(shù)體,通過關(guān)鍵字"function"來定義:
function add(num1, num2) { return num1 + num2; }
上述代碼就定義了一個名為"add"的函數(shù),該函數(shù)接受兩個參數(shù)num1和num2,并將它們相加后返回結(jié)果。
另一種方式是函數(shù)表達(dá)式,這種方式相對于聲明式來說稍微有點(diǎn)復(fù)雜,但是也非常實(shí)用。函數(shù)表達(dá)式將一個函數(shù)封裝成一個變量并賦值,也可以將函數(shù)作為參數(shù)傳遞給其他函數(shù)。它的基本結(jié)構(gòu)如下:
var add = function (num1, num2) { return num1 + num2; };
將函數(shù)封裝成變量,我們可以將函數(shù)作為某些條件的返回值或者調(diào)用某個函數(shù)后的返回值:
var getAddFunc = function () { return function (num1, num2) { return num1 + num2; }; }; var add = getAddFunc(); alert(add(2,3)); //5
除了這兩種方式外,javascript還有一些高級定義函數(shù)的方式,比如使用構(gòu)造函數(shù)創(chuàng)建函數(shù)等。
在定義函數(shù)時,還有一些常見的問題需要注意:
1.屬性和方法封裝:
函數(shù)可以封裝一些私有屬性和方法,不讓外部訪問:
function MyClass() { var name = "小明"; function setName(newName) { name = newName; } function getName() { return name; } //暴露出公有方法,使用this關(guān)鍵字 this.getName = getName; this.setName = setName; }
2.函數(shù)返回值:
函數(shù)的返回值要么有,要么沒有,一個函數(shù)可以返回另一個函數(shù),也可以返回一個對象、數(shù)組甚至是dom節(jié)點(diǎn)等:
function getAdd() { return function (num1, num2) { return num1 + num2; }; } //返回一個函數(shù) alert(getAdd()(2, 3)); //5
3.函數(shù)重載:
javascript中沒有函數(shù)重載這個概念,但是我們可以通過if語句等判斷語句來實(shí)現(xiàn)根據(jù)參數(shù)數(shù)量等條件調(diào)用不同的函數(shù)。
總之,在javascript中,函數(shù)擁有著極為重要的地位,學(xué)習(xí)和掌握好函數(shù)的定義和使用,對于我們編寫復(fù)雜的交互式網(wǎng)頁至關(guān)重要。