- 相關(guān)推薦
javascript編程常用知識的應用
1.null 與 undefined
* 從一個(gè)對象中獲取某個(gè)屬性,如果該對象及其 prototype 鏈 中的對象都沒(méi)有該屬性的時(shí)候,該屬性的值為 undefined 。
* 一個(gè) function 如果沒(méi)有顯式的通過(guò) return 來(lái)返回值給其調用者的話(huà),其返回值就是 undefined 。有一個(gè)特例就是在使用new的時(shí)候。
* JavaScript 中的 function 可以聲明任意個(gè)形式參數,當該 function 實(shí)際被調用的時(shí)候,傳入的參數的個(gè)數如果小于聲明的形式參數,那么多余的形式參數的值為 undefined 。
* null為空對象,注意與空的對象({})的區別。
簡(jiǎn)單來(lái)說(shuō),對于所有變量,只要聲明后還沒(méi)有指定初始值 ,那么他就是undefined,如果是Object類(lèi)型用來(lái)表示空引用的概念,那么就是用null來(lái)表示。
2.if 表達式
* Null總是為假(false)
* Undefined總是為假(false)
* Number+0,-0 或是 NaN 的時(shí)候為假,其它值為真
* String空字符串的時(shí)候為假,其它值為真
* Object總是為真(true)
3.Array
JavaScript 中的數組(Array)和通常的編程語(yǔ)言,如 Java 或是 C/C++ 中的有很大不同。在 JavaScript 中的對象就是一個(gè)無(wú)序的關(guān)聯(lián)數組,而 Array 正是利用 JavaScript 中對象的這種特性來(lái)實(shí)現的。在 JavaScript 中,Array 其實(shí)就是一個(gè)對象,只不過(guò)它的屬性名是整數,另外有許多額外的屬性(如 length)和方法(如 splice)等方便地操作數組。
4.new 運算符
JavaScript 中并沒(méi)有 Java 中的類(lèi)(class)的概念,而是采用構造器(constructor)的方式來(lái)創(chuàng )建對象。在 new 表達式中使用構造器就可以創(chuàng )建新的對象。由構造器創(chuàng )建出來(lái)的對象有一個(gè)隱含的引用指向該構造器的 prototype 。
5.prototype
prototype是javascript原型繼承的核心概念,大家一定在某個(gè)javascript類(lèi)庫里面見(jiàn)過(guò) Array.prototype.push.call()這樣的用法,所以歸根結底prototype是一個(gè)對象。我們可以通過(guò) prototype給native class添加一些有用的方法,也可以通過(guò)prototype實(shí)現繼承。如果對prototype比較感興趣,可以在ff里面通過(guò)__proto__來(lái)訪(fǎng) 問(wèn)指定對象的原型鏈。
6.scope chain
執行上下文(execution context)是 ECMAScript 規范中用來(lái)描述 JavaScript 代碼執行的抽象概念。所有的 JavaScript 代碼都是在某個(gè)執行上下文中運行的。在當前執行上下文中調用 function 的時(shí)候,會(huì )進(jìn)入一個(gè)新的執行上下文。當該 function 調用結束的時(shí)候,會(huì )返回到原來(lái)的執行上下文中。如果 function 調用過(guò)程中拋出異常,并沒(méi)有被捕獲的話(huà),有可能從多個(gè)執行上下文中退出。在 function 調用過(guò)程,也可能調用其它的 function,從而進(jìn)入新的執行上下文。由此形成一個(gè)執行上下文棧。
注:如果對scope chain比較感興趣,可以在ff里面通過(guò)__parent__屬性來(lái)訪(fǎng)問(wèn)函數的scope chain,比較遺憾的是ff的js引擎SpiderMonkey對這個(gè)屬性的支持不是很完美,出現內部函數的時(shí)候會(huì )出錯,所以建議用Rhino
注:這里需要提的是注意函數表達式和函數聲明對scope chain的影響。
7.closure
閉包也算是js比較常用的特色功能了,一般我們在java里面執行完畢的一個(gè)函數,內部變量將全部被回收,但在javascript中,我們可以通過(guò)某些方法,使執行完的函數的內部變量依然存在,并且可訪(fǎng)問(wèn),這樣就構成了一個(gè)閉包。
當然,什么東西都有兩面性,閉包給我們帶來(lái)好處的時(shí)候,也會(huì )帶來(lái)不少的麻煩,比如一個(gè)不留神就產(chǎn)生了內存的泄漏,所以我們需要合理的應用這些技術(shù)。如果要 深入學(xué)習閉包,建議去看幾個(gè)js library(prototype,jquery,mootools),里面有一些很經(jīng)典的閉包應用,比如bind方法等,這里就不多贅述。
【javascript編程常用知識的應用】相關(guān)文章:
javascript編程異常處理的方法08-04
常用的JavaScript模式09-22
javascript基礎知識大全08-22
抽象語(yǔ)法樹(shù)在JavaScript中的應用08-18
PHP的基礎編程與應用10-16
JavaScript常用方法匯總10-25
關(guān)jQuery彈出窗口簡(jiǎn)單實(shí)現代碼-javascript編程06-07
javascript閉包的定義及應用實(shí)例分析08-25
JavaScript數組常用方法介紹09-04