程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 更多編程語言 >> 更多關於編程 >> ECMAScript中函數function類型

ECMAScript中函數function類型

編輯:更多關於編程

       這篇文章主要介紹了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");//不推薦

      從技術角度講,這是一個函數表達式。但是,我們不推薦使用這種方法定義函數, 因為這種語法會導致解析兩次代碼(第一次解析常規的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有所幫助。

    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved