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

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

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

    Cyh的博客

    Email:kissyan4916@163.com
    posts - 26, comments - 19, trackbacks - 0, articles - 220

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

    簡略語句

    JavaScript 可以使用簡略語句快速創(chuàng)建對象和數(shù)組,比如下面的代碼:

    可以使用簡略語句如下:

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

    創(chuàng)建數(shù)組的傳統(tǒng)方法是:

    使用簡略語句則:

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


    可以簡略為:

    JSON 數(shù)據(jù)格式

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

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

    JavaScript 本地函數(shù) (Math, Array 和 String)

    JavaScript 有很多內(nèi)置函數(shù),有效的使用,可以避免很多不必要的代碼,比如,從一個數(shù)組中找出最大值,傳統(tǒng)的方法是:

    使用內(nèi)置函數(shù)可以更容易實現(xiàn):

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

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

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

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

    使用 split 和 join 方法則直觀優(yōu)雅得多:

    事件代理

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

    傳統(tǒng)的事件處理是遍歷各個鏈接,加上各自的事件處理:

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

    匿名函數(shù)與 Module 模式

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

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

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

    如果這個函數(shù)不會被調(diào)用,可以更直接為:

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

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

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

    代碼配置

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

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

    你應(yīng)當在最后一步做這項工作,這里有一個文章,交付代碼前的5件事值的參考。

    同后臺交互

    JavaScript 是一門前臺語言,你需要別的語言同后臺交互,并返回數(shù)據(jù),使用 AJAX,你可以讓 JavaScript 直接使用同后臺的交互,將復雜的數(shù)據(jù)處理交由后臺處理。

    JavaScript 框架

    自己編寫適應(yīng)各種瀏覽器的代碼是完全浪費時間,應(yīng)當選擇一個 JavaScript 框架,讓這些復雜的事情交給框架處理。

    更多資源

    延伸閱讀

    本文國際來源:Smashing Magazine Seven JavaScript Things I Wish I Knew Much Earlier In My Career (原文作者:Christian Heilmann



                                                                                                           --    學海無涯
            

    主站蜘蛛池模板: 亚洲导航深夜福利| 国产在线19禁免费观看| 亚洲综合色在线观看亚洲| 亚洲AV无码AV吞精久久| 成年人性生活免费视频| 亚洲精品天堂成人片AV在线播放| av无码国产在线看免费网站| 亚洲国产高清在线精品一区| 性xxxxx免费视频播放| 亚洲av无码一区二区三区观看| 台湾一级毛片永久免费| 亚洲精品免费网站| 国产色爽女小说免费看| 美美女高清毛片视频黄的一免费| 亚洲精品偷拍视频免费观看| 三年片在线观看免费| 99亚洲精品高清一二区| 精品久久久久国产免费| 亚洲第一se情网站| 亚洲中文字幕无码久久精品1| 免费无码又爽又刺激高潮软件 | a在线观看免费视频| 亚洲国产成人高清在线观看| 99在线观看视频免费| 中文字幕乱码亚洲精品一区| 男人的天堂亚洲一区二区三区| 亚洲成av人片天堂网无码】| 亚洲国产精品日韩| 久久免费视频精品| 亚洲精品久久无码av片俺去也| 亚洲成?Ⅴ人在线观看无码| 久久免费视频网站| 久久亚洲精品国产精品婷婷 | 牛牛在线精品免费视频观看| 亚洲精品乱码久久久久久久久久久久| 91久久精品国产免费一区| 亚洲av综合av一区二区三区 | 亚洲三级在线免费观看| 亚洲av午夜成人片精品电影| 久久久久免费看成人影片| 亚洲国产精品成人AV在线|