欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

ECMAScript中函數function類型

 更新時間:2015年06月03日 10:43:59   投稿:hebedich  
這篇文章主要介紹了ECMAScript中函數function類型的相關資料,需要的朋友可以參考下

說起來ECMAScript中上面最有意思,我想那莫過于函數了,有意思的根源,則在于函數實際上是對象。每個函數都是Function類型的實例,而且都與其他引用類型一樣具有屬性和方法。由于函數是對象,因此函數名實際上也是一個指向函數對象的指針,不會與某個函數綁定。函數通常是使用函數聲明語法定義的,如下例子:

復制代碼 代碼如下:

 function sum(num1,num2)
 {
    return num1+num2;
 }

這與下面使用函數表達式定義函數的方式幾乎相差無幾。

復制代碼 代碼如下:

 var sum=function(num1,num2)
 {
     return num1+num2;
 };

  以上代碼定了變量sum并將其初始化為一個函數。你們會注意到,function關鍵字后面沒有函數名。這是因為在使用函數表達式定義函數時,沒有必要使用函數名(通過變量sum既可以引用函數)。另外,還要注意函數末尾有一個分號,就像聲明其他變量時一樣。

  最后一種定義函數的方式是使用Function構造函數。Function構造函數可以接受任意數量的參數,但最后一個參數始終都會被看成函數體,而前面的參數則枚舉出了新函數的參數。如下例子:

復制代碼 代碼如下:

var sum=new Function("num1","num2","return num1+num2");//不推薦

  從技術角度講,這是一個函數表達式。但是,我們不推薦使用這種方法定義函數, 因為這種語法會導致解析兩次代碼(第一次解析常規(guī)的ECMAScript代碼,第二次是解析傳入構造函數中的字符串),從而影響性能。不過,這種語法對于理解“函數是對象,函數名是指針”的概念都是非常直觀的。

由于函數名僅僅是指向函數的指針,因此函數名與包含對象指針的其他變量沒有什么不同。換句話說,一個函數可能會有多個名字,如下例子:

復制代碼 代碼如下:

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

  以上代碼首先定義了一個名為sum()的函數,用于求兩個值的和。然后,有聲明了變量anotherSum,并將其設置為sum()相等(將sum的值賦給anotherSum)。注意,使用不帶圓括號的函數名是訪問函數指針,而非調用函數。此時,anotherSum和sum 就指向了同一個函數,因此anotherSum()也可以被調用并返回結果。即使將sum設置為null,讓它與函數“斷絕關系”,但仍然可以證明正常調用anotherSum()。

以上所述就是本文的全部內容了,希望能夠對大家學習javascript有所幫助。

相關文章

  • js 代碼集(學習js的朋友可以看下)

    js 代碼集(學習js的朋友可以看下)

    js 代碼集 學習js的朋友可以看下,功能比較多,大家可以自己選擇。
    2009-07-07
  • js自執(zhí)行函數的幾種不同寫法的比較

    js自執(zhí)行函數的幾種不同寫法的比較

    js自執(zhí)行函數的幾種不同寫法的比較,需要的朋友可以參考下
    2012-08-08
  • JavaScript中閉包的詳解

    JavaScript中閉包的詳解

    本文主要介紹了JavaScript中閉包的相關知識。具有很好的參考價值。下面跟著小編一起來看下吧
    2017-04-04
  • 為什么js中不推薦使用eval函數(原因分析)

    為什么js中不推薦使用eval函數(原因分析)

    'eval'函數是javascript中的一個內置函數,它的主要作用是將傳入的字符串作為代碼來執(zhí)行,這篇文章主要介紹了為什么js中不推薦使用eval函數,需要的朋友可以參考下
    2023-10-10
  • js獲取最近一周一個月三個月時間的簡單示例

    js獲取最近一周一個月三個月時間的簡單示例

    時間的獲取和格式化是我們經常遇到的問題,下面這篇文章主要給大家介紹了關于利用js如何獲取最近一周一個月三個月時間的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2021-12-12
  • 利用element-ui實現遠程搜索兩種實現方式

    利用element-ui實現遠程搜索兩種實現方式

    這篇文章主要介紹了利用element-ui的兩種遠程搜索實現代碼,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2023-12-12
  • 利用JS實現scroll自定義滾動效果詳解

    利用JS實現scroll自定義滾動效果詳解

    這篇文章主要給大家介紹了關于利用JS如何實現scroll自定義滾動效果的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。
    2017-10-10
  • Bootstrap 實現表格樣式、表單布局的實例代碼

    Bootstrap 實現表格樣式、表單布局的實例代碼

    這篇文章主要介紹了Bootstrap 實現表格樣式、表單布局的實例代碼,需要的朋友可以參考下
    2018-12-12
  • javascript的事件觸發(fā)器介紹的實現

    javascript的事件觸發(fā)器介紹的實現

    這篇文章主要介紹了javascript的事件觸發(fā)器介紹的實現,本文所指觸發(fā)器是用程序來觸發(fā)綁定的事件,而不是人為的去觸發(fā),需要的朋友可以參考下
    2014-06-06
  • 一文教你如何優(yōu)雅的使用WebSocket

    一文教你如何優(yōu)雅的使用WebSocket

    WebSocket最大特點就是服務器可以主動向客戶端推送信息,客戶端也可以主動向服務器發(fā)送信息,是真正的雙向平等對話,屬于服務器推送技術的一種,下面這篇文章主要給大家介紹了關于如何優(yōu)雅的使用WebSocket的相關資料,需要的朋友可以參考下
    2022-05-05

最新評論