javascript編程常用知識(shí)的應(yīng)用

    時(shí)間:2024-08-12 02:34:14 JavaScript 我要投稿
    • 相關(guān)推薦

    javascript編程常用知識(shí)的應(yīng)用

      1.null 與 undefined

    javascript編程常用知識(shí)的應(yīng)用

      * 從一個(gè)對(duì)象中獲取某個(gè)屬性,如果該對(duì)象及其 prototype 鏈 中的對(duì)象都沒(méi)有該屬性的時(shí)候,該屬性的值為 undefined 。

      * 一個(gè) function 如果沒(méi)有顯式的通過(guò) return 來(lái)返回值給其調(diào)用者的話,其返回值就是 undefined 。有一個(gè)特例就是在使用new的時(shí)候。

      * JavaScript 中的 function 可以聲明任意個(gè)形式參數(shù),當(dāng)該 function 實(shí)際被調(diào)用的時(shí)候,傳入的參數(shù)的個(gè)數(shù)如果小于聲明的形式參數(shù),那么多余的形式參數(shù)的值為 undefined 。

      * null為空對(duì)象,注意與空的對(duì)象({})的區(qū)別。

      簡(jiǎn)單來(lái)說(shuō),對(duì)于所有變量,只要聲明后還沒(méi)有指定初始值 ,那么他就是undefined,如果是Object類型用來(lái)表示空引用的概念,那么就是用null來(lái)表示。

      2.if 表達(dá)式

      * Null總是為假(false)

      * Undefined總是為假(false)

      * Number+0,-0 或是 NaN 的時(shí)候?yàn)榧伲渌禐檎?/p>

      * String空字符串的時(shí)候?yàn)榧伲渌禐檎?/p>

      * Object總是為真(true)

      3.Array

      JavaScript 中的數(shù)組(Array)和通常的編程語(yǔ)言,如 Java 或是 C/C++ 中的有很大不同。在 JavaScript 中的對(duì)象就是一個(gè)無(wú)序的關(guān)聯(lián)數(shù)組,而 Array 正是利用 JavaScript 中對(duì)象的這種特性來(lái)實(shí)現(xiàn)的。在 JavaScript 中,Array 其實(shí)就是一個(gè)對(duì)象,只不過(guò)它的屬性名是整數(shù),另外有許多額外的屬性(如 length)和方法(如 splice)等方便地操作數(shù)組。

      4.new 運(yùn)算符

      JavaScript 中并沒(méi)有 Java 中的類(class)的概念,而是采用構(gòu)造器(constructor)的方式來(lái)創(chuàng)建對(duì)象。在 new 表達(dá)式中使用構(gòu)造器就可以創(chuàng)建新的對(duì)象。由構(gòu)造器創(chuàng)建出來(lái)的對(duì)象有一個(gè)隱含的引用指向該構(gòu)造器的 prototype 。

      5.prototype

      prototype是javascript原型繼承的核心概念,大家一定在某個(gè)javascript類庫(kù)里面見(jiàn)過(guò) Array.prototype.push.call()這樣的用法,所以歸根結(jié)底prototype是一個(gè)對(duì)象。我們可以通過(guò) prototype給native class添加一些有用的方法,也可以通過(guò)prototype實(shí)現(xiàn)繼承。如果對(duì)prototype比較感興趣,可以在ff里面通過(guò)__proto__來(lái)訪 問(wèn)指定對(duì)象的原型鏈。

      6.scope chain

      執(zhí)行上下文(execution context)是 ECMAScript 規(guī)范中用來(lái)描述 JavaScript 代碼執(zhí)行的抽象概念。所有的 JavaScript 代碼都是在某個(gè)執(zhí)行上下文中運(yùn)行的。在當(dāng)前執(zhí)行上下文中調(diào)用 function 的時(shí)候,會(huì)進(jìn)入一個(gè)新的執(zhí)行上下文。當(dāng)該 function 調(diào)用結(jié)束的時(shí)候,會(huì)返回到原來(lái)的執(zhí)行上下文中。如果 function 調(diào)用過(guò)程中拋出異常,并沒(méi)有被捕獲的話,有可能從多個(gè)執(zhí)行上下文中退出。在 function 調(diào)用過(guò)程,也可能調(diào)用其它的 function,從而進(jìn)入新的執(zhí)行上下文。由此形成一個(gè)執(zhí)行上下文棧。

      注:如果對(duì)scope chain比較感興趣,可以在ff里面通過(guò)__parent__屬性來(lái)訪問(wèn)函數(shù)的scope chain,比較遺憾的是ff的js引擎SpiderMonkey對(duì)這個(gè)屬性的支持不是很完美,出現(xiàn)內(nèi)部函數(shù)的時(shí)候會(huì)出錯(cuò),所以建議用Rhino 

      注:這里需要提的是注意函數(shù)表達(dá)式和函數(shù)聲明對(duì)scope chain的影響。

      7.closure

      閉包也算是js比較常用的特色功能了,一般我們?cè)趈ava里面執(zhí)行完畢的一個(gè)函數(shù),內(nèi)部變量將全部被回收,但在javascript中,我們可以通過(guò)某些方法,使執(zhí)行完的函數(shù)的內(nèi)部變量依然存在,并且可訪問(wèn),這樣就構(gòu)成了一個(gè)閉包。

      當(dāng)然,什么東西都有兩面性,閉包給我們帶來(lái)好處的時(shí)候,也會(huì)帶來(lái)不少的麻煩,比如一個(gè)不留神就產(chǎn)生了內(nèi)存的泄漏,所以我們需要合理的應(yīng)用這些技術(shù)。如果要 深入學(xué)習(xí)閉包,建議去看幾個(gè)js library(prototype,jquery,mootools),里面有一些很經(jīng)典的閉包應(yīng)用,比如bind方法等,這里就不多贅述。

      

    【javascript編程常用知識(shí)的應(yīng)用】相關(guān)文章:

    javascript編程異常處理的方法08-04

    常用的JavaScript模式09-22

    關(guān)于javascript的基礎(chǔ)知識(shí)06-13

    javascript基礎(chǔ)知識(shí)大全08-22

    抽象語(yǔ)法樹(shù)在JavaScript中的應(yīng)用08-18

     PHP的基礎(chǔ)編程與應(yīng)用10-16

    JavaScript常用方法匯總10-25

    關(guān)jQuery彈出窗口簡(jiǎn)單實(shí)現(xiàn)代碼-javascript編程06-07

    javascript閉包的定義及應(yīng)用實(shí)例分析08-25

    JavaScript數(shù)組常用方法介紹09-04

    91久久大香伊蕉在人线_国产综合色产在线观看_欧美亚洲人成网站在线观看_亚洲第一无码精品立川理惠

      一级a爱片国产亚洲精品 | 先锋午夜影音久久 | 亚洲日韩首页中文字幕在线 | 欧洲国产又粗又猛又爽的视频 | 日本一卡久久伊人大国麻 | 新sss乱码视频在线观看 |