DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> JavaScript基礎知識 >> JS和函數式語言的三特性
JS和函數式語言的三特性
編輯:JavaScript基礎知識     

首先要有一個概念:並不是一個語言支持函數,這個語言就可以叫做“函數式語言”。函數式語言中的函數(function),除了能被調用之外,還具有一些其他性質。有以下三點:
1. 函數是運算元
2. 在函數內保存數據
3. 函數內的運算對函數外無副作用
一、函數是運算元
普通的函數調用時,可以抽象的理解為:函數就是一個運算符,傳入的參數是運算元;
但當JavaScript中的函數作為另一個函數的參數使用時,是傳遞引用的,這個“傳入參數”就可以被理解為是一個運算元。由此的結論是,(作為“傳入參數”的)函數具有運算元的含義,“函數參數”與普通參數並沒有什麼不同。

二、在函數內保存數據
在命令式語言中,函數內部的私有變量(局部變量)是不能被保存的。從程序的執行方式上來講,局部變量在棧上分配,在函數執行結束後,所占用的棧被釋放。因此函數內的數據不可能被保存。
在JavaScript的函數中,函數內的私有變量可以被修改,而且當再次“進入”到該函數內部時,這個被修改的狀態仍將持續。下面的例子說明了這個特性:
復制代碼 代碼如下:
  var set,get;
  function MyFunc(){
      var value = 100;

      function set_value(v){
          value = v;
      }
      function get_value(){
          return value;
      }

      set = set_value;
      get = get_value;
  } 
  MyFunc();
  console.log(get()); //100
  set(300);
  console.log(get()); //300
顯而易見的一個好處是,如果一個數據能夠在函數內持續保存,那麼該函數(作為構造器)賦給實例時就可以使用這些數據進行運算;而在多個實例之間,由於數據存在於不同的閉包中,由此相互不會產生影響。
以面向對象的術語來解釋,就是說不同的實例有各自的私有數據(復制自某個公共的數據)。下面的例子說明了這個特性:
復制代碼 代碼如下:
  function MyObject(){
      var value = 100;
      this.setValue = function(){
          value = v;
      }
      this.showValue = function(){
          console.log(value);
      }
  }
  var obj1 = new MyObject();
  var obj2 = new MyObject();

  obj2.setValue(300);
  obj1.showValue(); //100;
三、函數內的運算對函數外無副作用
這一特性的含義在於:
* 函數使用入口參數進行運算,而不修改它(作為值參數而不是變量參數使用)
* 在運算過程中不會修改函數外部的其他數據的值(例如全局變量)
* 運算結束後通過“函數返回”向外部系統傳值

這樣的函數在運算過程中對外部系統是無副作用的。然而我們注意到,JavaScript允許在函數內部引用和修改全局變量,甚至可以聲明全局變量。這一點其實是破壞它的函數式特性的。
除此之外,JavaScript也允許在函數內修改對象和數組成員————這些成員應該由對象方法而非對象系統外的其他函數來修改。
所以:JavaScript這項特性只能通過開發人員的編程習慣來保證。

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved