成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

那些不為人熟知的JavaScript技巧

開發(fā) 前端
文章將從7個(gè)方面講述JavaScript中那些你不很熟知但非常實(shí)用的技巧,對(duì)于Web開發(fā)者來(lái)說(shuō)是非常有用的,有助于提高編寫代碼的效率。

JavaScript的成功讓人津津樂道,為Web網(wǎng)頁(yè)編寫JavaScript代碼已經(jīng)是所有Web設(shè)計(jì)師的基本功,這門有趣的語(yǔ)言蘊(yùn)藏著許多不為人熟知的東西,即使多年的 JavaScript 程序員,也未能完全吃透。

簡(jiǎn)略語(yǔ)句

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

簡(jiǎn)略語(yǔ)句

可以使用簡(jiǎn)略語(yǔ)句如下:

簡(jiǎn)略語(yǔ)句

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

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

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

使用簡(jiǎn)略語(yǔ)句則:

簡(jiǎn)略語(yǔ)句

另一個(gè)可以使用簡(jiǎn)略語(yǔ)句的地方是條件判斷語(yǔ)句:

簡(jiǎn)略語(yǔ)句的地方是條件判斷語(yǔ)句

可以簡(jiǎn)略為:

可以簡(jiǎn)略為

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

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

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

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

顯示在你自己的網(wǎng)站

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

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

JavaScript 本地函數(shù)

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

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

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

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

你可以用這個(gè)方法幫助探測(cè)瀏覽器

這解決了IE瀏覽器的一個(gè)問題,通過這種方法,你總是可以找到那個(gè)正確的值,因?yàn)闉g覽器不支持的那個(gè)值會(huì)返回 undefined。

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

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

#p#
事件代理

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

HTML 代碼

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

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

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

使用事件代理,可以直接處理,無(wú)需遍歷

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

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

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

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

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

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

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

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

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

對(duì)象或函數(shù)

這就是所謂Module模式或單例模式(Singleton),該模式為Douglas Crockford所推崇,并被大量應(yīng)用在 Yahoo User Interface Library YUI。假如你想在別的地方調(diào)用里面的方法,又不想在調(diào)用前使用myApplication這個(gè)對(duì)象名,可以在匿名函數(shù)中返回這些方法,甚至用簡(jiǎn)稱返回:

Module模式或單例模式

代碼配置

別人使用你編寫的 JavaScript 代碼的時(shí)候,難免會(huì)更改某些代碼,但這會(huì)很困難,因?yàn)椴皇敲總€(gè)人都很容易讀懂別人的代碼,與其這樣,不如創(chuàng)建一個(gè)代碼配置對(duì)象,別人只需要在這個(gè)對(duì)象中更改某些配置即可實(shí)現(xiàn)代碼的更改。這里有一篇 JavaScript 配置對(duì)象詳解的文章,簡(jiǎn)單說(shuō):

1.在代碼中創(chuàng)建一個(gè)叫做 configuration 的對(duì)象;

2.里面保存所有可以更改的配置,如 CSS ID 和類名,按鈕的標(biāo)簽文字,描述性文字,本地化語(yǔ)言設(shè)置;

3.將該對(duì)象設(shè)置為全局對(duì)象,以便別人直接訪問并改寫;

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

同后臺(tái)交互

JavaScript是一門前臺(tái)語(yǔ)言,你需要?jiǎng)e的語(yǔ)言同后臺(tái)交互,并返回?cái)?shù)據(jù),使用 AJAX,你可以讓 JavaScript 直接使用同后臺(tái)的交互,將復(fù)雜的數(shù)據(jù)處理交由后臺(tái)處理。

JavaScript框架

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

【編輯推薦】

  1. JavaScript最讓人費(fèi)解的十件事
  2. 兩種JavaScript解析引擎性能對(duì)比談
  3. JavaScript挺入服務(wù)器端開發(fā)語(yǔ)言序列
  4. 詳解Javascript框架中的全局變量
  5. 詳解Javascript中checkbox樹的功能

 

責(zé)任編輯:王曉東 來(lái)源: cnbeta
相關(guān)推薦

2019-11-18 09:19:59

Vim命令模式

2010-09-03 08:52:38

CSS

2020-02-20 12:02:32

Python數(shù)據(jù)函數(shù)

2017-03-28 08:40:14

2010-09-06 14:19:54

CSS

2012-07-12 15:04:56

Windows 7操作系統(tǒng)

2020-10-25 15:27:30

程序員技術(shù)網(wǎng)絡(luò)

2015-11-02 14:42:12

2013-07-18 13:15:18

2019-06-05 12:49:07

云辦公

2024-09-26 16:28:42

Pythonif代碼

2015-11-27 10:13:19

數(shù)據(jù)中心

2019-12-12 20:49:05

JavaScript語(yǔ)言運(yùn)算符

2024-03-04 16:32:02

JavaScript運(yùn)算符

2025-04-24 08:05:00

Linuxsort命令排序

2017-08-16 17:00:19

2010-08-05 11:14:12

Flex優(yōu)勢(shì)

2025-02-25 13:00:00

JavaScript開發(fā)前端

2018-03-23 09:00:00

開源ArduinoDebian

2013-08-09 09:27:08

vCentervSphere
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 国产日韩一区二区三免费 | 久久久久国产精品一区二区 | 色天堂影院 | 北条麻妃一区二区三区在线视频 | 成人永久免费视频 | a在线观看 | 天天干狠狠 | 精品视频久久久久久 | 日本不卡一区二区三区 | 日韩在线不卡视频 | 伊人欧美视频 | 在线免费观看成年人视频 | 99久久免费精品国产免费高清 | 中文字幕在线观看第一页 | 久久久久国色av免费观看性色 | 国产精品久久久久久久7电影 | 亚洲一二三区免费 | 精品国产一区二区三区四区在线 | 97精品超碰一区二区三区 | 午夜网| 亚洲乱码一区二区三区在线观看 | 在线观看国产wwwa级羞羞视频 | 国产欧美在线视频 | 欧美日韩成人在线 | 91精品国产综合久久小仙女图片 | 午夜精品一区二区三区在线观看 | 亚洲精品国产精品国自产在线 | 男女激情网站免费 | 国产剧情一区 | 日韩中文字幕在线观看视频 | 久久爱一区 | 在线观看中文字幕av | 日本一区二区三区在线观看 | 国产高清精品一区二区三区 | a毛片视频网站 | 亚洲国产精品久久 | 久久久亚洲成人 | 久久精品国产一区二区三区不卡 | 天天夜碰日日摸日日澡 | 亚洲国产成人av好男人在线观看 | 欧美一区二区成人 |