<dfn id="w48us"></dfn><ul id="w48us"></ul>
  • <ul id="w48us"></ul>
  • <del id="w48us"></del>
    <ul id="w48us"></ul>
  • javascript編程常用知識的應用

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

    javascript編程常用知識的應用

      1.null 與 undefined

    javascript編程常用知識的應用

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

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

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

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

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

      2.if 表達式

      * Null總是為假(false)

      * Undefined總是為假(false)

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

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

      * 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 

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

      7.closure

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

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

      

    【javascript編程常用知識的應用】相關文章:

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

    常用的JavaScript模式09-22

    關于javascript的基礎知識06-13

    javascript基礎知識大全08-22

    抽象語法樹在JavaScript中的應用08-18

     PHP的基礎編程與應用10-16

    JavaScript常用方法匯總10-25

    關jQuery彈出窗口簡單實現代碼-javascript編程06-07

    javascript閉包的定義及應用實例分析08-25

    JavaScript數組常用方法介紹09-04

    主站蜘蛛池模板: 精品久久人人妻人人做精品| 亚洲精品视频免费观看| 精品日本一区二区三区在线观看 | 国内精品伊人久久久久| 亚洲精品国产美女久久久| 精品亚洲视频在线观看| 成人精品一区二区久久| 国产乱码精品一区二区三区四川人| 午夜精品一区二区三区免费视频| 日本熟妇亚洲欧美精品区 | 国产精品久久久亚洲| 中文成人无字幕乱码精品区| 精品乱子伦一区二区三区| 国产福利电影一区二区三区,亚洲国模精品一区 | 亚洲精品第一国产综合境外资源| 国产一级精品高清一级毛片| 久久精品一区二区| 99在线热播精品免费99热| 精品视频无码一区二区三区| 日本aⅴ精品中文字幕| 无码精品人妻一区二区三区中| 亚洲国产精品一区第二页| 亚洲精品乱码久久久久久蜜桃图片| 合区精品中文字幕| 中文字幕无码精品三级在线电影| 午夜精品一区二区三区在线视 | 99久久成人国产精品免费| 国产精品无码日韩欧| 国产精品三级在线观看无码| 欧美日韩成人精品久久久免费看 | 色久综合网精品一区二区| 伊人 久久 精品| 中文字幕亚洲精品无码| 亚洲爆乳精品无码一区二区三区| 亚洲精品美女久久久久99| 精品无人码麻豆乱码1区2区| 国产成人精品免费久久久久| 91国在线啪精品一区| 久久国产精品久久久| 国产精品美女WWW爽爽爽视频| 精品欧美一区二区在线看片|