自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

給JavaScript初學(xué)者的24個(gè)小竅門(mén)

開(kāi)發(fā) 前端
本文為JavaScript初學(xué)者總結(jié)了24條小竅門(mén)。一些比較重要的,如不要省略大括號(hào),在頁(yè)面底部加載腳本,在循環(huán)外聲明變量等等,十分易學(xué)實(shí)用。

為JavaScript做一點(diǎn)性能小提升吧!

本文列出了24條能讓你的代碼編寫(xiě)過(guò)程更為輕松高效的建議。也許您還是JavaScript初學(xué)者,剛剛寫(xiě)完自己的Hello World,那這里有很多對(duì)您的工作將十分有用的小貼士;也許有些技巧您已經(jīng)知道,那就試試快速瀏覽一下,看能不能發(fā)現(xiàn)一點(diǎn)新東西吧!

1. 用 === 代替 ==

JavaScript里有兩種不同的相等運(yùn)算符:===|!== 和==|!=。相比之下,前者更值得推薦。請(qǐng)盡量使用前者。

“如果兩個(gè)比較對(duì)象有著同樣的類(lèi)型和值,===返回true,!==返回false。”
– JavaScript: The Good Parts

不過(guò),如果使用==和!=,在操作不同數(shù)據(jù)類(lèi)型時(shí), 你可能會(huì)遇到一些意想不到的問(wèn)題。在進(jìn)行相等判斷前,JavaScript會(huì)試圖將它們轉(zhuǎn)換為字符串、數(shù)字或 Boolean量。

2. 避免使用Eval函數(shù)

Eval函數(shù)把一個(gè)字串作為參數(shù),并把字串作為JavaScript語(yǔ)句執(zhí)行,返回結(jié)果。

此函數(shù)不僅會(huì)降低你腳本的執(zhí)行效率,而且還大大增加了安全風(fēng)險(xiǎn),因?yàn)樗x予了作為文本的參數(shù)太大的權(quán)利。千萬(wàn)別用!

3. 不要使用快速寫(xiě)法

技術(shù)上說(shuō),你可以省略掉大部分花括弧和句尾分號(hào),絕大多數(shù)瀏覽器都能正確執(zhí)行以下語(yǔ)句:

  1. if(someVariableExists)   
  2. x = false 

不過(guò),如果是這樣的呢:

  1. if(someVariableExists)   
  2. x = false 
  3. anotherFunctionCall(); 

你可能會(huì)認(rèn)為它和下面的語(yǔ)句相等:

  1. if(someVariableExists) {   
  2. x = false;   
  3. anotherFunctionCall();  
  4. }

不幸的是,事實(shí)并非如此?,F(xiàn)實(shí)情況是它等價(jià)于:

  1. if(someVariableExists) {   
  2. x = false;   
  3. }
  4. anotherFunctionCall(); 

如您注意到的,再漂亮的縮進(jìn)也不能代替這華麗的花括弧。在所有情況下都請(qǐng)寫(xiě)清楚花括號(hào)和句尾分號(hào)。在只有一行語(yǔ)句的時(shí)候能偶爾省略掉,雖然下這么做也是極度不被推薦的:

  1. if(2 + 2 === 4) return 'nicely done'

多考慮下將來(lái)吧,孩子

假設(shè),在將來(lái)的開(kāi)發(fā)過(guò)程中,你需要為這個(gè) if 語(yǔ)句添加更多的命令呢?到時(shí)候你還不是得把括號(hào)給加上?

4. 好好利用JS Lint

JSLint 是由 Douglas Crockford 編寫(xiě)的一個(gè)調(diào)試器。你只需要貼上你的代碼,它就能快速為您掃描出任何明顯的錯(cuò)誤和問(wèn)題。

“JSLint 掃描接收的代碼。發(fā)現(xiàn)問(wèn)題,描述問(wèn)題,并給出其在源碼中的大概位置??砂l(fā)現(xiàn)的問(wèn)題包括但不限于語(yǔ)法錯(cuò)誤,雖然語(yǔ)法錯(cuò)誤確實(shí)是最常見(jiàn)的。JSLint也會(huì)用約定俗成的習(xí)慣檢查代碼的格式化風(fēng)格,以及結(jié)構(gòu)錯(cuò)誤。通過(guò)JSLint的掃描并不能保證你的程序就完全正確。它只是為您提供了額外一雙發(fā)現(xiàn)錯(cuò)誤的眼睛?!?
– JSLint 文檔

完成代碼之前,把它放到JSLint里檢查一下,快速消滅你的無(wú)心之過(guò)。

#p#

5. 在頁(yè)面底部加載腳本

正如下圖所示:

Place JS at bottom 

請(qǐng)記住—— 我們要千方百計(jì)保證客戶端的頁(yè)面載入速度盡可能的快。而腳本沒(méi)載入完成,瀏覽器就沒(méi)法加載頁(yè)面的剩余部分。

如果你的JS文件只是添加一些額外功能——例如,為點(diǎn)擊某鏈接綁定事件——那大可以等頁(yè)面加載基本完成后再做。把JS文件放到頁(yè)面***,body的結(jié)束標(biāo)簽之前,這樣做***了。

更好的寫(xiě)法是

  1. < p>現(xiàn)在你知道我最喜歡的玉米是哪種了。< /p>   
  2. < script type="text/javascript" src="path/to/file.js">< /script>   
  3. < script type="text/javascript" src="path/to/anotherFile.js">< /script>   
  4. < /body>   
  5. < /html> 

6. 在 For 語(yǔ)句外部聲明變量

當(dāng)需要執(zhí)行冗長(zhǎng)的for語(yǔ)句時(shí),不要讓JavaScript引擎每次都重復(fù)那些沒(méi)有必要的操作。例如:

這樣不好

  1. for(var i = 0; i <  someArray.length; i++) {   
  2. var container = document.getElementById('container');   
  3. container.innerHtml += 'my number: ' + i;   
  4. console.log(i);   

這段代碼每次都重新定義數(shù)組長(zhǎng)度,每次都在遍歷DOM尋找container元素 —— 太傻了!

這樣好多了

  1. var container = document.getElementById('container');   
  2. for(var i = 0, len = someArray.length; i <  len;  i++) {   
  3. container.innerHtml += 'my number: ' + i;   
  4. console.log(i);   

7. 快速構(gòu)建字串

要對(duì)一個(gè)數(shù)組或?qū)ο笞鲅h(huán)操作時(shí),不要老惦記著一表人才的for語(yǔ)句,拿點(diǎn)創(chuàng)意出來(lái)嘛!明明就還有很多更快的辦法:

  1. var arr = ['item 1''item 2''item 3', ...];   
  2. var list = '< ul>< li>' + arr.join('< /li>< li>') + '< /li>< /ul>'

“沒(méi)那么多繁文縟節(jié)來(lái)煩你;你就信我一次好了(或者你也可以自己試一試)—— 這真的是迄今能找到的最快辦法了!

用點(diǎn)土辦法,也別管它背后究竟發(fā)生了什么抽象的東西,通常土辦法都比那些優(yōu)雅的辦法要快捷得多!”
– James Padolsey, james.padolsey.com

8. 減少全局變量

“把你踩在全局的那些亂七八糟的腳印都?xì)w于一人名下,能顯著降低與其他應(yīng)用、小工具或JS庫(kù)沖突的可能性?!?
– Douglas Crockford

  1. var name = 'Jeffrey';   
  2. var lastName = 'Way';   
  3. function doSomething() {...}   
  4. console.log(name); // Jeffrey -- 也有可能是 window.name 

更好的寫(xiě)法

  1. var DudeNameSpace = {   
  2. name : 'Jeffrey',   
  3. lastName : 'Way',   
  4. doSomething : function() {...}   
  5. }   
  6. console.log(DudeNameSpace.name); // Jeffrey 

注意看,我們是如何戲劇化地把“亂七八糟的腳印”都?xì)w到“DudeNameSpace”這對(duì)象之下的。

#p#

9. 寫(xiě)好注釋

可能一開(kāi)始你會(huì)覺(jué)得并無(wú)必要,但相信我,你將來(lái)會(huì)主動(dòng)想要盡可能寫(xiě)好代碼的注釋的。當(dāng)你幾個(gè)月后再回看某項(xiàng)目時(shí),結(jié)果卻發(fā)現(xiàn)很難想起當(dāng)時(shí)寫(xiě)某句東西時(shí)腦子在想的什么了,是不是很讓人沮喪呢?或者,如果有同事要修訂你的代碼呢?一定,一定要為你代碼里的重要部分加上注釋。

  1. // 遍歷數(shù)組,輸出各自名稱   
  2. for(var i = 0, len = array.length; i <  len; i++) {   
  3. console.log(array[i]);   

10. 試試漸進(jìn)增強(qiáng)

一定要記得為未啟用JavaScript的情況提供替代方案。大家可能會(huì)認(rèn)為,“大部分我的訪客都啟用了JavaScript的,我才不用擔(dān)心”。這樣的話,你可就大錯(cuò)特錯(cuò)了!

你有沒(méi)有試過(guò)看看禁用JavaScript后你那漂亮的滑動(dòng)器都成啥樣了?(你可以下載 Web Developer ToolBar 輕松完成這項(xiàng)任務(wù)。)禁用之后你的網(wǎng)站可能就徹底失去了可用性!經(jīng)驗(yàn)之談:開(kāi)發(fā)初期總是按照沒(méi)有JavaScript來(lái)設(shè)計(jì)你的網(wǎng)站,之后再進(jìn)行漸進(jìn)地功能增強(qiáng),小心翼翼地改變你地布局。

11. 不要傳遞字串給 “setInterval” 或 “setTimeout”

看看下面的代碼:

  1. setInterval(   
  2. "document.getElementById('container').innerHTML += 'My new number: ' + i", 3000   
  3. ); 

不僅執(zhí)行不高效,而且和 eval 函數(shù)有著同樣的高風(fēng)險(xiǎn)。千萬(wàn)不要把字串傳遞給 setInterval 和 setTimeout。恰當(dāng)?shù)淖龇ㄊ?,傳遞一個(gè)函數(shù)名:

  1. setInterval(someFunction, 3000); 

12. 不要使用with語(yǔ)句

初識(shí)之下,“with”語(yǔ)句似乎還挺好用的。它用于設(shè)置代碼在特定對(duì)象中的作用域。其基本用法是提供深入到對(duì)象中處理元素的快速寫(xiě)法。例如:

  1. with (being.person.man.bodyparts) {   
  2. arms = true;   
  3. legs = true;   

– 等價(jià)于 —

  1. being.person.man.bodyparts.arms = true;   
  2. being.person.man.bodyparts.legs= true

不幸的是,測(cè)試表明,若你要為對(duì)象插入新成員,with的表現(xiàn)非常糟糕,它的執(zhí)行速度非常緩慢。替代方案是聲明一個(gè)變量:

  1. var o = being.person.man.bodyparts;   
  2. o.arms = true;   
  3. o.legs = true

13. 使用 {},而不用New Object()

在JavaScript有多種方式能新建對(duì)象。最傳統(tǒng)的方法是 new 語(yǔ)句,如下:

  1. var o = new Object();   
  2. o.name = 'Benhuoer';   
  3. o.lastName = 'Yang';   
  4. o.someFunction = function() {   
  5. console.log(this.name);   

不過(guò),這一方法讀起來(lái)卻比較糟糕。我強(qiáng)烈建議你采用下面這種在文字樣式上更為強(qiáng)健的寫(xiě)法:

更好的寫(xiě)法

  1. var o = {   
  2. name: 'Jeffrey',   
  3. lastName = 'Way',   
  4. someFunction : function() {   
  5. console.log(this.name);   
  6. }   
  7. }; 

注意,如果你想新建一個(gè)空對(duì)象,用 {} 就能行:

  1. var o = {}; 

“對(duì)象字面符(Objects literals)幫助我們寫(xiě)出支持很多特性,同時(shí)又關(guān)聯(lián)性強(qiáng)、簡(jiǎn)明直接的代碼。沒(méi)必要直接調(diào)用新建語(yǔ)句,然后再費(fèi)心維護(hù)聲明變量和傳遞變量的語(yǔ)句之間的正確順序,等等?!?– dyn-web.com

14. 使用[],而不用New Array()

新建數(shù)組時(shí)的同類(lèi)型運(yùn)用。

行得通的寫(xiě)法

  1. var a = new Array();   
  2. a[0] = "Joe";   
  3. a[1] = 'Plumber'

更好的寫(xiě)法

  1. var a = ['Joe','Plumber']; 

“在JavaScript編程中經(jīng)常遇到的一個(gè)錯(cuò)誤是,該用數(shù)組時(shí)卻用了對(duì)象,該用對(duì)象時(shí)卻用了數(shù)組。規(guī)則其實(shí)很簡(jiǎn)單:當(dāng)屬性名是小的連續(xù)整數(shù)時(shí),你應(yīng)該使用數(shù)組。其他情況,使用對(duì)象?!?– Douglas Crockford

#p#

15. 一長(zhǎng)列變量聲明?別寫(xiě)那么多var,用逗號(hào)吧

  1. var someItem = 'some string';   
  2. var anotherItem = 'another string';   
  3. var oneMoreItem = 'one more string'

更好的寫(xiě)法

  1. var someItem = 'some string',   
  2. anotherItem = 'another string',   
  3. oneMoreItem = 'one more string'

…不言自明。我不知道這樣做能否提升代碼執(zhí)行速度,但是確實(shí)讓你的代碼干凈許多。

17. 千萬(wàn)千萬(wàn)記得寫(xiě)分號(hào)

大部分瀏覽器都允許你不寫(xiě)句尾分號(hào):

  1. var someItem = 'some string' 
  2. function doSomething() {   
  3. return 'something' 

之前已經(jīng)說(shuō)過(guò),這樣做會(huì)造成潛在的更大、更難以發(fā)現(xiàn)的問(wèn)題:

更好的寫(xiě)法

  1. var someItem = 'some string';   
  2. function doSomething() {   
  3. return 'something';   

18. “For in” 語(yǔ)句

遍歷對(duì)象時(shí),你可能會(huì)發(fā)現(xiàn)你還需要獲取方法函數(shù)。所以遇到這種情況時(shí),請(qǐng)一定記得給你的代碼包一層 if 語(yǔ)句,用以過(guò)濾信息。

  1. for(key in object) {   
  2. if(object.hasOwnProperty(key) {   
  3. ...這里做點(diǎn)什么...   
  4. }   

引自 Douglas Crockford 所作: JavaScript: The Good Parts

19. 使用Firebug的“Timer”功能優(yōu)化你的代碼

想要輕松地快速了解某項(xiàng)操作的用時(shí)嗎?使用Firebug的timer功能來(lái)記錄結(jié)果好了。

  1. function TimeTracker(){   
  2. console.time("MyTimer");   
  3. for(x=5000; x > 0; x--){}   
  4. console.timeEnd("MyTimer");   

20. 讀,讀,讀……

雖然我是Web開(kāi)發(fā)博客的超級(jí)粉絲,但吃飯和睡覺(jué)前除了看書(shū)好像也別無(wú)選擇~ 在你的床頭柜上擺一本W(wǎng)eb開(kāi)發(fā)的好書(shū)吧!

21. 自決的函數(shù)

相比于調(diào)用函數(shù),讓函數(shù)在頁(yè)面載入或者某一父函數(shù)被調(diào)用時(shí)自動(dòng)執(zhí)行,是十分簡(jiǎn)單方便的做法。你只需要把你的函數(shù)包在父輩之內(nèi),然后添上一個(gè)額外的括號(hào),本質(zhì)上這括號(hào)就觸發(fā)了你定義的函數(shù)(了解更多)。

  1. (function doSomething() {   
  2. return {   
  3. name: 'jeff',   
  4. lastName: 'way' 
  5. };   
  6. })(); 

22. 原生 JavaScript 總是會(huì)比使用代碼庫(kù)來(lái)的快

諸如jQuery和Mootools這樣的JavaScript庫(kù),能為你寫(xiě)代碼的過(guò)程省下不少時(shí)間——尤其是當(dāng)需要 AJAX 操作時(shí)。不過(guò)你可得記住,只要你的代碼寫(xiě)得恰當(dāng),原生JavaScript總是會(huì)比利用代碼庫(kù)的寫(xiě)法執(zhí)行得快一些。

jQuery的“each” 方法對(duì)于循環(huán)操作十分便利,但是使用原生態(tài)的for語(yǔ)句總歸會(huì)快很多。

23. Crockford 的 JSON.Parse

盡管 JavaScript 2會(huì)內(nèi)建JSON處理器,但寫(xiě)這篇文章之時(shí),我們還是需要自己實(shí)現(xiàn)。Douglas Crockford,JSON的創(chuàng)建者,已經(jīng)為我們創(chuàng)作出能直接使用的處理器了。您可以在這里下載。

導(dǎo)入這段代碼,你就能新建 JSON 全局對(duì)象,然后處理你的 .json 文件。

  1. var response = JSON.parse(xhr.responseText);    
  2. var container = document.getElementById('container');   
  3. for(var i = 0, len = response.length; i <  len; i++) {   
  4. container.innerHTML += '< li>' + response[i].name + ' : ' + response[i].email + '< /li>';   

24. 移去“Language”

很多年前,language還是每段script標(biāo)簽必備屬性:

  1. < script type="text/javascript" language="javascript">   
  2. ...   
  3. < /script> 

不過(guò)現(xiàn)在,這屬性已經(jīng)沒(méi)啥用很久了…… 所以,刪掉算啦!

就這些了,朋友們~

就是這些了,這就是我給JavaScript初學(xué)者的24條小建議。各位親愛(ài)的朋友,你們的看法呢?你們有什么快速小貼士嗎?感謝你的耐心閱讀。

原文:24-javascript-best-practices-for-beginners

【編輯推薦】

  1. Javascript中最常用的25個(gè)經(jīng)典技巧
  2. 6月編程語(yǔ)言排行榜:JavaScript轉(zhuǎn)正在即
  3. 非常全面的實(shí)用JavaScript開(kāi)發(fā)工具列表
  4. Google專(zhuān)家:JavaScript是網(wǎng)站性能的致命克星
  5. 痛陳Javascript的缺點(diǎn)
責(zé)任編輯:yangsai 來(lái)源: 笨活兒
相關(guān)推薦

2013-12-12 10:20:00

JavaScript學(xué)習(xí)

2011-04-12 10:13:24

2011-07-04 14:14:54

java

2011-04-08 15:07:40

C++

2015-09-28 11:15:03

java初學(xué)者建議

2018-04-08 14:47:06

Linux命令type

2018-04-24 11:09:13

LinuxShellfc

2018-05-14 08:53:51

Linux命令shuf

2011-06-01 09:27:08

JavaScript

2011-01-11 08:45:17

JavaScript

2016-11-18 17:40:35

2021-05-06 09:00:00

JavaScript靜態(tài)代碼開(kāi)發(fā)

2022-06-15 15:30:29

Linux新用戶建議

2016-11-11 20:33:53

Hadoop大數(shù)據(jù)云計(jì)算

2009-02-18 11:10:40

c++忠告方法

2020-08-07 07:05:48

JavaScript開(kāi)發(fā)技術(shù)

2020-09-18 09:02:20

JavaScript

2011-09-16 09:38:19

Emacs

2022-04-24 15:21:01

MarkdownHTML

2024-08-17 12:14:06

點(diǎn)贊
收藏

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