JavaScript實(shí)用技巧(一)
簡(jiǎn)略語(yǔ)句
JavaScript 可以使用簡(jiǎn)略語(yǔ)句快速創(chuàng)建對(duì)象和數(shù)組,比如下面的代碼:
car.colour = 'red';
car.wheels = 4;
car.hubcaps = 'spinning';
car.age = 4;
可以使用簡(jiǎn)略語(yǔ)句如下:
colour:'red',
wheels:4,
hubcaps:'spinning',
age:4
}
對(duì)象 car 就此創(chuàng)建,不過(guò)需要特別注意,結(jié)束花括號(hào)前一定不要加 ";" 否則在 IE 會(huì)遇到很大麻煩。
創(chuàng)建數(shù)組的傳統(tǒng)方法是:
'test1','test2','test3','test4'
);
使用簡(jiǎn)略語(yǔ)句則:
另一個(gè)可以使用簡(jiǎn)略語(yǔ)句的地方是條件判斷語(yǔ)句:
if(x < 200){
direction = 1;
}else{
direction = -1;
}
//可以簡(jiǎn)略為:
var direction = x < 200 ? 1 : -1;
JSON 數(shù)據(jù)格式
JSON 是 "JavaScript Object Notation" 的縮寫,由 Douglas Crockford 設(shè)計(jì),JSON 改變了 JavaScript 在緩存復(fù)雜數(shù)據(jù)格式方面的困境,如下例,假如你要描述一個(gè)樂(lè)隊(duì),可以這樣寫:
"name":"My name is test1",
"Members":[
{"name":"name1","role":"role1"},
{"name":"name2","role":"role2"},
{"name":"name3","role":"role3"},
{"name":"name4","role":"role4"}
],
"year":"2010"
}
你可以在 JavaScript 中直接使用 JSON,甚至作為某些 API 的返回?cái)?shù)據(jù)對(duì)象,以下代碼調(diào)用著名書(shū)簽網(wǎng)站 delicious.com 的一個(gè) API,返回你在該網(wǎng)站的所有書(shū)簽,并顯示在你自己的網(wǎng)站:
<script>
function delicious(o){
var out = '<ul>';
for(var i = 0;i<o.length;i++){
out +='<li><a href="'+o[i].u+'">'+o[i].d+'</a></li>';
}
out += '</ul>';
document.getElementById('delicious').innerHTML = out;
}
</script>
<script src="http://feeds.delicious.com/v2/json/codepo8/javascript?count=15&callback=delicious"></script>
JavaScript 本地函數(shù) (Math, Array 和 String)
JavaScript 有很多內(nèi)置函數(shù),有效的使用,可以避免很多不必要的代碼,比如,從一個(gè)數(shù)組中找出最大值,傳統(tǒng)的方法是:
var max = 0;
for(var i = 0;i<numbers.length;i++){
if(numbers[i] > max){
max = numbers[i];
}
}
alert(max);
使用內(nèi)置函數(shù)可以更容易實(shí)現(xiàn):
numbers.sort(function(a,b){return b - a});
alert(numbers[0]);
另一個(gè)方法是使用 Math.max() 方法:
你可以用這個(gè)方法幫助探測(cè)瀏覽器
這解決了 IE 瀏覽器的一個(gè)問(wèn)題,通過(guò)這種方法,你總是可以找到那個(gè)正確的值,因?yàn)闉g覽器不支持的那個(gè)值會(huì)返回 undefined。
還可以使用 JavaScript 內(nèi)置的 split() 和 join() 函數(shù)處理 HTML 對(duì)象的 CSS 類名,如果 HTML 對(duì)象的類名是空格隔開(kāi)的多個(gè)名字,你在為它追加或刪除一個(gè) CSS 類名的時(shí)候需要特別注意,如果該對(duì)象還沒(méi)有類名屬性,可以直接將新的類名賦予它,如果已經(jīng)存在類名,新增的類名前必須有一個(gè)空格,用傳統(tǒng)的 JavaScript 方法是這樣實(shí)現(xiàn)的:
var c = elm.className;
elm.className = (c == '')?newclass: c+' '+newclass;
}
使用 split 和 join 方法則直觀優(yōu)雅得多:
var classes = elm.className.split(' ');
classes.push(newclass);
elm.className = classes.join(' ');
}
事件代理
與其在 HTML 文檔中設(shè)計(jì)一堆事件,不如直接設(shè)計(jì)一個(gè)事件代理,舉例說(shuō)明,假如你有一些鏈接,用戶點(diǎn)擊后不想打開(kāi)鏈接,而是執(zhí)行某個(gè)事件,HTML 代碼如下:
傳統(tǒng)的事件處理是遍歷各個(gè)鏈接,加上各自的事件處理:
使用事件代理,可以直接處理,無(wú)需遍歷:
匿名函數(shù)與 Module 模式
JavaScript 的一個(gè)問(wèn)題是,任何變量,函數(shù)或是對(duì)象,除非是在某個(gè)函數(shù)內(nèi)部定義,否則,就是全局的,意味著同一網(wǎng)頁(yè)的別的代碼可以訪問(wèn)并改寫這個(gè)變量(ECMA 的 JavaScript 5 已經(jīng)改變了這一狀況 - 譯者),使用匿名函數(shù),你可以繞過(guò)這一問(wèn)題。
比如,你有這樣一段代碼,很顯然,變量 name, age, status 將成為全局變量
為了避免這一問(wèn)題,你可以使用匿名函數(shù):
如果這個(gè)函數(shù)不會(huì)被調(diào)用,可以更直接為:
如果要訪問(wèn)其中的對(duì)象或函數(shù),可以:
這就是所謂 Module 模式或單例模式(Singleton),該模式為 Douglas Crockford 所推崇,并被大量應(yīng)用在 Yahoo User Interface Library YUI。
假如你想在別的地方調(diào)用里面的方法,又不想在調(diào)用前使用 myApplication 這個(gè)對(duì)象名,可以在匿名函數(shù)中返回這些方法,甚至用簡(jiǎn)稱返回:
代碼配置
別人使用你編寫的 JavaScript 代碼的時(shí)候,難免會(huì)更改某些代碼,但這會(huì)很困難,因?yàn)椴皇敲總€(gè)人都很容易讀懂別人的代碼,與其這樣,不如創(chuàng)建一個(gè)代碼配置對(duì)象,別人只需要在這個(gè)對(duì)象中更改某些配置即可實(shí)現(xiàn)代碼的更改。這里有一篇 JavaScript 配置對(duì)象詳解的文章,簡(jiǎn)單說(shuō):
- 在代碼中創(chuàng)建一個(gè)叫做 configuration 的對(duì)象
- 里面保存所有可以更改的配置,如 CSS ID 和類名,按鈕的標(biāo)簽文字,描述性文字,本地化語(yǔ)言設(shè)置
- 將該對(duì)象設(shè)置為全局對(duì)象,以便別人直接訪問(wèn)并改寫
你應(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ù)雜的事情交給框架處理。
相關(guān)文章
在WordPress中加入Google搜索功能的簡(jiǎn)單步驟講解
這篇文章主要介紹了在WordPress中加入Google搜索的簡(jiǎn)單步驟講解,谷歌搜索很有用,但同時(shí)也要注意在國(guó)內(nèi)使用cse的連通性,需要的朋友可以參考下2016-01-01使用非html5實(shí)現(xiàn)js板連連看游戲示例代碼
連連看游戲通常情況下都是使用html5來(lái)實(shí)現(xiàn)的,不過(guò)從現(xiàn)在開(kāi)始就可以使用js來(lái)實(shí)現(xiàn)了,具體的代碼如下,喜歡的朋友可以參考下,希望對(duì)大家有所幫助2013-09-09詳解小程序如何改變onLoad的執(zhí)行時(shí)機(jī)
這篇文章主要介紹了詳解小程序如何改變onLoad的執(zhí)行時(shí)機(jī),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11JavaScript.The.Good.Parts閱讀筆記(二)作用域&閉包&減緩全局空間污染
塊級(jí)作用域: 大多數(shù)使用c語(yǔ)言語(yǔ)法的語(yǔ)言都有塊級(jí)作用域,而JavaScript沒(méi)有塊級(jí)作用域。2010-11-11javaScript中push函數(shù)用法實(shí)例分析
這篇文章主要介紹了javaScript中push函數(shù)用法,較為詳細(xì)的分析了javascript中push函數(shù)的功能、定義及使用技巧,需要的朋友可以參考下2015-06-06實(shí)現(xiàn)兩個(gè)文本框同時(shí)輸入的實(shí)例
下面小編就為大家?guī)?lái)一篇實(shí)現(xiàn)兩個(gè)文本框同時(shí)輸入的實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-09-09如何利用JS通過(guò)身份證號(hào)獲取當(dāng)事人的生日、年齡、性別
身份證可以識(shí)別一個(gè)人的信息,下面就介紹一下如何利用js通過(guò)身份證號(hào)碼獲取當(dāng)事人的年齡和性別2016-01-01動(dòng)態(tài)創(chuàng)建script標(biāo)簽實(shí)現(xiàn)跨域資源訪問(wèn)的方法介紹
本篇文章主要是對(duì)動(dòng)態(tài)創(chuàng)建script標(biāo)簽實(shí)現(xiàn)跨域資源訪問(wèn)的方法進(jìn)行了介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2014-02-02