• <sub id="h4knl"><ol id="h4knl"></ol></sub>
    <sup id="h4knl"></sup>
      <sub id="h4knl"></sub>

      <sub id="h4knl"><ol id="h4knl"><em id="h4knl"></em></ol></sub><s id="h4knl"></s>
      1. <strong id="h4knl"></strong>

      2. javascript編程常用知識的應(yīng)用

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

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

          1.null 與 undefined

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

          * 從一個對象中獲取某個屬性,如果該對象及其 prototype 鏈 中的對象都沒有該屬性的時候,該屬性的值為 undefined 。

          * 一個 function 如果沒有顯式的通過 return 來返回值給其調(diào)用者的話,其返回值就是 undefined 。有一個特例就是在使用new的時候。

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

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

          簡單來說,對于所有變量,只要聲明后還沒有指定初始值 ,那么他就是undefined,如果是Object類型用來表示空引用的概念,那么就是用null來表示。

          2.if 表達式

          * Null總是為假(false)

          * Undefined總是為假(false)

          * Number+0,-0 或是 NaN 的時候為假,其它值為真

          * String空字符串的時候為假,其它值為真

          * Object總是為真(true)

          3.Array

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

          4.new 運算符

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

          5.prototype

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

          6.scope chain

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

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

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

          7.closure

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

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

          

        《&.doc》
        将本文的Word文档下载到电脑,方便收藏和打印
        推荐度:
        点击下载文档

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

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

        常用的JavaScript模式09-22

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

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

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

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

        JavaScript常用方法匯總10-25

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

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

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

        国产高潮无套免费视频_久久九九兔免费精品6_99精品热6080YY久久_国产91久久久久久无码
      3. <sub id="h4knl"><ol id="h4knl"></ol></sub>
        <sup id="h4knl"></sup>
          <sub id="h4knl"></sub>

          <sub id="h4knl"><ol id="h4knl"><em id="h4knl"></em></ol></sub><s id="h4knl"></s>
          1. <strong id="h4knl"></strong>

          2. 中文亚洲无线码欧美 | 伊人久久大香线蕉综合男男 | 亚洲欧美日韩在线观看视 | 亚洲日本香蕉视在线播放 | 亚洲日韩久久久中文字幕 | 亚洲日韩欧美在线精品 |

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

              1.null 與 undefined

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

              * 從一個對象中獲取某個屬性,如果該對象及其 prototype 鏈 中的對象都沒有該屬性的時候,該屬性的值為 undefined 。

              * 一個 function 如果沒有顯式的通過 return 來返回值給其調(diào)用者的話,其返回值就是 undefined 。有一個特例就是在使用new的時候。

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

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

              簡單來說,對于所有變量,只要聲明后還沒有指定初始值 ,那么他就是undefined,如果是Object類型用來表示空引用的概念,那么就是用null來表示。

              2.if 表達式

              * Null總是為假(false)

              * Undefined總是為假(false)

              * Number+0,-0 或是 NaN 的時候為假,其它值為真

              * String空字符串的時候為假,其它值為真

              * Object總是為真(true)

              3.Array

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

              4.new 運算符

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

              5.prototype

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

              6.scope chain

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

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

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

              7.closure

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

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