DIV CSS 佈局教程網

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

       本文內容是我閱讀《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