ECMAScript中函數(shù)function類型
說起來ECMAScript中上面最有意思,我想那莫過于函數(shù)了,有意思的根源,則在于函數(shù)實(shí)際上是對象。每個(gè)函數(shù)都是Function類型的實(shí)例,而且都與其他引用類型一樣具有屬性和方法。由于函數(shù)是對象,因此函數(shù)名實(shí)際上也是一個(gè)指向函數(shù)對象的指針,不會(huì)與某個(gè)函數(shù)綁定。函數(shù)通常是使用函數(shù)聲明語法定義的,如下例子:
function sum(num1,num2)
{
return num1+num2;
}
這與下面使用函數(shù)表達(dá)式定義函數(shù)的方式幾乎相差無幾。
var sum=function(num1,num2)
{
return num1+num2;
};
以上代碼定了變量sum并將其初始化為一個(gè)函數(shù)。你們會(huì)注意到,function關(guān)鍵字后面沒有函數(shù)名。這是因?yàn)樵谑褂煤瘮?shù)表達(dá)式定義函數(shù)時(shí),沒有必要使用函數(shù)名(通過變量sum既可以引用函數(shù))。另外,還要注意函數(shù)末尾有一個(gè)分號,就像聲明其他變量時(shí)一樣。
最后一種定義函數(shù)的方式是使用Function構(gòu)造函數(shù)。Function構(gòu)造函數(shù)可以接受任意數(shù)量的參數(shù),但最后一個(gè)參數(shù)始終都會(huì)被看成函數(shù)體,而前面的參數(shù)則枚舉出了新函數(shù)的參數(shù)。如下例子:
var sum=new Function("num1","num2","return num1+num2");//不推薦
從技術(shù)角度講,這是一個(gè)函數(shù)表達(dá)式。但是,我們不推薦使用這種方法定義函數(shù), 因?yàn)檫@種語法會(huì)導(dǎo)致解析兩次代碼(第一次解析常規(guī)的ECMAScript代碼,第二次是解析傳入構(gòu)造函數(shù)中的字符串),從而影響性能。不過,這種語法對于理解“函數(shù)是對象,函數(shù)名是指針”的概念都是非常直觀的。
由于函數(shù)名僅僅是指向函數(shù)的指針,因此函數(shù)名與包含對象指針的其他變量沒有什么不同。換句話說,一個(gè)函數(shù)可能會(huì)有多個(gè)名字,如下例子:
function sum(num1,num2)
{
return num1+num2;
}
alert(sum(10,10));//20
var anotherSum=sum;
alert(anotherSum(10,10));//20
sum=null;
alert(anotherSum(10,10));//20
以上代碼首先定義了一個(gè)名為sum()的函數(shù),用于求兩個(gè)值的和。然后,有聲明了變量anotherSum,并將其設(shè)置為sum()相等(將sum的值賦給anotherSum)。注意,使用不帶圓括號的函數(shù)名是訪問函數(shù)指針,而非調(diào)用函數(shù)。此時(shí),anotherSum和sum 就指向了同一個(gè)函數(shù),因此anotherSum()也可以被調(diào)用并返回結(jié)果。即使將sum設(shè)置為null,讓它與函數(shù)“斷絕關(guān)系”,但仍然可以證明正常調(diào)用anotherSum()。
以上所述就是本文的全部內(nèi)容了,希望能夠?qū)Υ蠹覍W(xué)習(xí)javascript有所幫助。
相關(guān)文章
js獲取最近一周一個(gè)月三個(gè)月時(shí)間的簡單示例
時(shí)間的獲取和格式化是我們經(jīng)常遇到的問題,下面這篇文章主要給大家介紹了關(guān)于利用js如何獲取最近一周一個(gè)月三個(gè)月時(shí)間的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2021-12-12利用element-ui實(shí)現(xiàn)遠(yuǎn)程搜索兩種實(shí)現(xiàn)方式
這篇文章主要介紹了利用element-ui的兩種遠(yuǎn)程搜索實(shí)現(xiàn)代碼,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2023-12-12利用JS實(shí)現(xiàn)scroll自定義滾動(dòng)效果詳解
這篇文章主要給大家介紹了關(guān)于利用JS如何實(shí)現(xiàn)scroll自定義滾動(dòng)效果的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2017-10-10Bootstrap 實(shí)現(xiàn)表格樣式、表單布局的實(shí)例代碼
這篇文章主要介紹了Bootstrap 實(shí)現(xiàn)表格樣式、表單布局的實(shí)例代碼,需要的朋友可以參考下2018-12-12javascript的事件觸發(fā)器介紹的實(shí)現(xiàn)
這篇文章主要介紹了javascript的事件觸發(fā)器介紹的實(shí)現(xiàn),本文所指觸發(fā)器是用程序來觸發(fā)綁定的事件,而不是人為的去觸發(fā),需要的朋友可以參考下2014-06-06