<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    秋風的蕭瑟 又見湖邊木葉飛

    歡迎來到梁良 | LonBlog,這里記錄下了我生活點點滴滴。

    JavaScript 技巧

    JavaScript 的成功讓人津津樂道,為 Web 網頁編寫 JavaScript 代碼已經是所有 Web 設計師的基本功,這門有趣的語言蘊藏著許多不為人熟知的東西,即使多年的 JavaScript 程序員,也未能完全吃透。本文從7個方面講述 JavaScript 中那些你不很熟知但非常實用的技巧。

    簡略語句
    JavaScript 可以使用簡略語句快速創建對象和數組,比如下面的代碼:



    可以使用簡略語句如下:



    對象 car 就此創建,不過需要特別注意,結束花括號前一定不要加 ";" 否則在 IE 會遇到很大麻煩。

    創建數組的傳統方法是:



    使用簡略語句則:



    另一個可以使用簡略語句的地方是條件判斷語句:




    可以簡略為:


    JSON 數據格式
    JSON 是 "JavaScript Object Notation" 的縮寫,由 Douglas Crockford 設計,JSON 改變了 JavaScript 在緩存復雜數據格式方面的困境,如下例,假如你要描述一個樂隊,可以這樣寫:



    你可以在 JavaScript 中直接使用 JSON,甚至作為某些 API 的返回數據對象,以下代碼調用著名書簽網站 delicious.com 的一個 API,返回你在該網站的所有書簽,并顯示在你自己的網站:


    JavaScript 本地函數 (Math, Array 和 String)
    JavaScript 有很多內置函數,有效的使用,可以避免很多不必要的代碼,比如,從一個數組中找出最大值,傳統的方法是:



    使用內置函數可以更容易實現:



    另一個方法是使用 Math.max() 方法:



    你可以用這個方法幫助探測瀏覽器



    這解決了 IE 瀏覽器的一個問題,通過這種方法,你總是可以找到那個正確的值,因為瀏覽器不支持的那個值會返回 undefined。

    還可以使用 JavaScript 內置的 split() 和 join() 函數處理 HTML 對象的 CSS 類名,如果 HTML 對象的類名是空格隔開的多個名字,你在為它追加或刪除一個 CSS 類名的時候需要特別注意,如果該對象還沒有類名屬性,可以直接將新的類名賦予它,如果已經存在類名,新增的類名前必須有一個空格,用傳統的 JavaScript 方法是這樣實現的:



    使用 split 和 join 方法則直觀優雅得多:


    事件代理
    與其在 HTML 文檔中設計一堆事件,不如直接設計一個事件代理,舉例說明,假如你有一些鏈接,用戶點擊后不想打開鏈接,而是執行某個事件,HTML 代碼如下:



    傳統的事件處理是遍歷各個鏈接,加上各自的事件處理:



    使用事件代理,可以直接處理,無需遍歷:


    匿名函數與 Module 模式
    JavaScript 的一個問題是,任何變量,函數或是對象,除非是在某個函數內部定義,否則,就是全局的,意味著同一網頁的別的代碼可以訪問并改寫這個變量(ECMA 的 JavaScript 5 已經改變了這一狀況 - 譯者),使用匿名函數,你可以繞過這一問題。

    比如,你有這樣一段代碼,很顯然,變量 name, age, status 將成為全局變量



    為了避免這一問題,你可以使用匿名函數:



    如果這個函數不會被調用,可以更直接為:



    如果要訪問其中的對象或函數,可以:



    這就是所謂 Module 模式或單例模式(Singleton),該模式為 Douglas Crockford 所推崇,并被大量應用在 Yahoo User Interface Library YUI

    假如你想在別的地方調用里面的方法,又不想在調用前使用 myApplication 這個對象名,可以在匿名函數中返回這些方法,甚至用簡稱返回:


    代碼配置
    別人使用你編寫的 JavaScript 代碼的時候,難免會更改某些代碼,但這會很困難,因為不是每個人都很容易讀懂別人的代碼,與其這樣,不如創建一個代碼配置對象,別人只需要在這個對象中更改某些配置即可實現代碼的更改。這里有一篇 JavaScript 配置對象詳解的文章,簡單說:

    • 在代碼中創建一個叫做 configuration 的對象
    • 里面保存所有可以更改的配置,如 CSS ID 和類名,按鈕的標簽文字,描述性文字,本地化語言設置
    • 將該對象設置為全局對象,以便別人直接訪問并改寫

    你應當在最后一步做這項工作,這里有一個文章,交付代碼前的5件事值的參考。
    同后臺交互
    JavaScript 是一門前臺語言,你需要別的語言同后臺交互,并返回數據,使用 AJAX,你可以讓 JavaScript 直接使用同后臺的交互,將復雜的數據處理交由后臺處理。
    JavaScript 框架
    自己編寫適應各種瀏覽器的代碼是完全浪費時間,應當選擇一個 JavaScript 框架,讓這些復雜的事情交給框架處理。
    更多資源 延伸閱讀

    posted on 2010-04-24 20:22 梁良 閱讀(148) 評論(0)  編輯  收藏


    只有注冊用戶登錄后才能發表評論。


    網站導航:
     
    <2010年4月>
    28293031123
    45678910
    11121314151617
    18192021222324
    2526272829301
    2345678

    導航

    公告

        歡迎光臨

    常用鏈接

    隨筆分類

    隨筆檔案

    相冊

    .我的網站.

    友情博客

    開源社區

    科技博客

    資料網站

    最新隨筆

    搜索

    最新評論

    閱讀排行榜

    Powered by:
    LonLeung
    Copyright © 梁良

    本頁生成時間:毫秒

    主站蜘蛛池模板: 日韩欧美亚洲中文乱码| AV在线播放日韩亚洲欧| 久久亚洲AV成人无码国产| 亚洲黄片手机免费观看| 国产精品无码一二区免费| 亚洲不卡影院午夜在线观看| 最近免费中文字幕中文高清| 免费a级毛片18以上观看精品| 亚洲制服丝袜第一页| 亚洲视频在线免费看| 久久久久亚洲AV无码麻豆| 久久精品私人影院免费看| 国产亚洲精品a在线无码| 中文字幕免费视频精品一| 伊人婷婷综合缴情亚洲五月| 美女被吸屁股免费网站| 可以免费观看一级毛片黄a| 亚洲aⅴ无码专区在线观看 | 中文字幕亚洲一区二区三区| 亚洲人成网站色7799| 四虎影永久在线高清免费| 羞羞视频免费网站含羞草| 亚洲av高清在线观看一区二区| 成人久久久观看免费毛片| 综合久久久久久中文字幕亚洲国产国产综合一区首 | 成人人观看的免费毛片| 亚洲狠狠色丁香婷婷综合| 成人永久免费高清| a免费毛片在线播放| 亚洲国产另类久久久精品小说 | 黄页网站在线看免费| 亚洲国产精品久久网午夜| 成年性午夜免费视频网站不卡| 亚洲国产精品99久久久久久| 成人免费无码大片A毛片抽搐| 美女露100%胸无遮挡免费观看 | 亚洲AV无码不卡无码| 日本免费xxxx| 免费一级做a爰片久久毛片潮| 在线观看亚洲天天一三视| 91精品导航在线网址免费|