javascript中常用編程知識

來源:互聯網
上載者:User

1.null 與 undefined

* 從一個對象中擷取某個屬性,如果該對象及其 prototype 鏈 中的對象都沒有該屬性的時候,該屬性的值為 undefined 。
* 一個 function 如果沒有顯式的通過 return 來傳回值給其調用者的話,其傳回值就是 undefined 。有一個特例就是在使用new的時候。
* JavaScript 中的 function 可以聲明任意個形式參數,當該 function 實際被調用的時候,傳入的參數的個數如果小於聲明的形式參數,那麼多餘的形式參數的值為 undefined 。
* null為空白對象,注意與空的對象({})的區別。
簡單來說,對於所有變數,只要聲明後還沒有指定初始值 ,那麼他就是undefined,如果是Object類型用來表示Null 參考的概念,那麼就是用null來表示。

2.if 運算式

* Null總是為假(false)
* Undefined總是為假(false)
* Number+0,-0 或是 NaN 的時候為假,其它值為真
* StringNull 字元串的時候為假,其它值為真
* Object總是為真(true)

3.Array

JavaScript 中的數組(Array)和通常的程式設計語言,如 Java 或是 C/C++ 中的有很大不同。在 JavaScript 中的對象就是一個無序的關聯陣列,而 Array 正是利用 JavaScript 中對象的這種特性來實現的。在 JavaScript 中,Array 其實就是一個對象,只不過它的屬性名稱是整數,另外有許多額外的屬性(如 length)和方法(如 splice)等方便地運算元組。

4.new 運算子

JavaScript 中並沒有 Java 中的類(class)的概念,而是採用構造器(constructor)的方式來建立對象。在 new 運算式中使用構造器就可以建立新的對象。由構造器建立出來的對象有一個隱含的引用指向該構造器的 prototype 。

5.prototype

prototype是javascript原型繼承的核心概念,大家一定在某個javascript類庫裡面見過 Array.prototype.push.call()這樣的用法,所以歸根結底prototype是一個對象。我們可以通過 prototype給native class添加一些有用的方法,也可以通過prototype實現繼承。如果對prototype比較感興趣,可以在ff裡面通過__proto__來訪 問指定對象的原型鏈。

6.scope chain

執行內容(execution context)是 ECMAScript 規範中用來描述 JavaScript 代碼執行的抽象概念。所有的 JavaScript 代碼都是在某個執行內容中啟動並執行。在當前執行內容中調用 function 的時候,會進入一個新的執行內容。當該 function 調用結束的時候,會返回到原來的執行內容中。如果 function 調用過程中拋出異常,並沒有被捕獲的話,有可能從多個執行內容中退出。在 function 調用過程,也可能調用其它的 function,從而進入新的執行內容。由此形成一個執行內容棧。

註:如果對scope chain比較感興趣,可以在ff裡面通過__parent__屬性來訪問函數的scope chain,比較遺憾的是ff的js引擎SpiderMonkey對這個屬性的支援不是很完美,出現內建函式的時候會出錯,所以建議用Rhino (http://developer.mozilla.org/en/docs/Rhino)。

註:這裡需要提的是注意函數運算式和函式宣告對scope chain的影響。

7.closure

閉包也算是js比較常用的特色功能了,一般我們在java裡面執行完畢的一個函數,內部變數將全部被回收,但在javascript中,我們可以通過某些方法,使執行完的函數的內部變數依然存在,並且可訪問,這樣就構成了一個閉包。

當然,什麼東西都有兩面性,閉包給我們帶來好處的時候,也會帶來不少的麻煩,比如一個不留神就產生了記憶體的泄漏,所以我們需要合理的應用這些技術。如果要 深入學習閉包,建議去看幾個js library(prototype,jquery,mootools),裡面有一些很經典的閉包應用,比如bind方法等,這裡就不多贅述。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.