成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

JavaScript最佳實踐20則

fuchenxuan / 3288人閱讀

摘要:本文總結了則的最佳實踐,希望對各位爪哇國編劇有用。使用有兩種等值運算符,分別是和,以及和。比較兩個值的時候,請使用前者,避免討厭的強制類型轉換帶來預料之外的結果。下只提供無強制類型轉換的別名和別名,不用頭疼選哪種。

本文總結了20則JavaScript的最佳實踐,希望對各位爪哇國編劇有用。(順帶推銷下CoffeeScript)

。

1. 使用 ===

JavaScript有兩種等值運算符,分別是=====,以及!==!=。比較兩個值的時候,請使用前者,避免JavaScript討厭的強制類型轉換帶來預料之外的結果。

CoffeeScript下只提供無強制類型轉換的==(別名is)和!=(別名isnt),不用頭疼選哪種。

2. eval很邪惡

eval讓我們將字符串作為參數(shù)執(zhí)行,這是非常強大的特性。然而,eval會大幅降低腳本的性能,也會引起安全問題。除非你打算用JavaScript寫一個編譯器,還是對eval敬而遠之的好。

3. 少打字多費腦

省掉一些花括號,大多數(shù)瀏覽器仍然能理解,例如:

if(someVariableExists)  
   x = false

然而,復雜一點的代碼就可能帶來問題:

if(someVariableExists)  
   x = false  
   anotherFunctionCall();

你想表達的也許是:

if(someVariableExists) {  
   x = false;  
   anotherFunctionCall();  
}

然而實際上等價于:

if(someVariableExists) {  
   x = false;  
}  
anotherFunctionCall();

所以,還是乖乖地寫花括號吧,這能為你省去無數(shù)麻煩。

如果你真那么討厭花括號,還是投入CoffeeScript的懷抱吧:

if someVariable?
  x = false

if someVariable?
  x = false
  anotherFunctionCall()

同理,大多數(shù)瀏覽器允許你省略分號:

var someItem = "some string"  
function doSomething() {  
  return "something"  
}

這和省略花括號一樣糟糕,還是老實一點好:

var someItem = "some string";  
function doSomething() {  
  return "something";  
}

或者,投奔CoffeeScript吧,不用分號了:

someItem = "some string"
doSomething = -> "something"

函數(shù)的寫法是不是也很帥?直接定義一個匿名函數(shù),然后把它賦給一個變量即可。

4. 使用JSLint

JSLint是一款非常棒的調(diào)試器,它會迅速找出代碼中的問題,包括語法錯誤、編碼風格和程序結構問題。

5. 將腳本放在頁面的底部

腳本加載是阻塞的,腳本加載并執(zhí)行完之后,瀏覽器不能繼續(xù)渲染下面的內(nèi)容。因此,用戶被迫等待更長時間。如果你的JavaScript腳本只是用來增強效果,那么請將它放在頁面的最后:

And now you know my favorite kinds of corn.

6. 避免在for語句中聲明變量

糟糕的例子:

for(var i = 0; i < someArray.length; i++) {  
   var container = document.getElementById("container");  
   container.innerHtml += "my number: " + i;  
   console.log(i);  
}

每次循環(huán)都要計算數(shù)組的長度,每次都要遍歷DOM查詢“container”元素,效率低下!

改成這樣就好一些:

var container = document.getElementById("container");  
for(var i = 0, len = someArray.length; i < len;  i++) {  
   container.innerHtml += "my number: " + i;  
   console.log(i);  
}
7. 構建字符串的最優(yōu)方法

遍歷數(shù)組或?qū)ο蟮臅r候不一定要用for,使用原生函數(shù)往往是更好的選擇:

var arr = ["item 1", "item 2", "item 3", ...];  
var list = "
  • " + arr.join("
  • ") + "
";
8. 減少全局變量

避免模塊和類庫互相干擾。

var name = "Jeffrey";  
var lastName = "Way";  

function doSomething() {...}  

console.log(name);

更好:

var DudeNameSpace = {  
   name : "Jeffrey",  
   lastName : "Way",  
   doSomething : function() {...}  
}  
console.log(DudeNameSpace.name)

CoffeeScipt下變量默認非全局,不需要加var,而且編譯的時候,整個.coffee文件處于一個函數(shù)之中,也就是說,一個獨立的命名空間。使用CoffeeScript,不用再操心全局變量問題。

9. 注釋

良好的注釋,幫助別人或者幾個月之后的你理解你的代碼。

10. 漸進增強

“大多數(shù)訪問者啟用了JavaScript,不必擔心”這是很大的誤區(qū)。

花費一點時間查看下你漂亮的頁面在javascript被關閉時是什么樣的吧。設計網(wǎng)站時,首先假定 JavaScript 是被禁用的,在此基礎上,漸進增強網(wǎng)站。

11. 不要給setIntervalsetTimeout傳遞字符串參數(shù)
setInterval(  
"document.getElementById("container").innerHTML += "My new number: " + i", 3000  
);

上面的代碼和eval如出一轍,效率低下。我們應該傳遞函數(shù):

setInterval(someFunction, 3000);
12. 別用with

看起來,使用with語句的代碼很清晰,例如:

with (being.person.man.bodyparts) {  
   arms = true;  
   legs = true;  
}

這比下面的要清爽得多:

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

很不幸,使用with語句導致添加新成員時性能低下,我們還是用變量吧:

var o = being.person.man.bodyparts;  
o.arms = true;  
o.legs = true;
13. 使用{}代替new Object()

new加構造函數(shù)可以創(chuàng)建對象:

var o = new Object();  
o.name = "Jeffrey";  
o.lastName = "Way";  
o.someFunction = function() {  
   console.log(this.name);  
}

這種方法多受詬病,更好的做法是:

var o = {  
   name: "Jeffrey",  
   lastName = "Way",  
   someFunction : function() {  
      console.log(this.name);  
   }  
};

這樣我們就不需要直接調(diào)用構造函數(shù),也不需要為傳遞給函數(shù)的參數(shù)的正確順序而提心吊膽。

14. 使用[]代替new Array()

創(chuàng)建數(shù)組也是一樣的道理。

var a = new Array();  
a[0] = "Joe";  
a[1] = "Plumber";

不如

var a = ["Joe","Plumber"];
15. 定義多個變量時,使用逗號
var someItem = "some string";  
var anotherItem = "another string";  
var oneMoreItem = "one more string";

不如這樣:

var someItem = "some string",  
    anotherItem = "another string",  
    oneMoreItem = "one more string";

這樣代碼更清晰。

CoffeeScript?正如我們前面提到的,變量默認非全局,所以我們根本不需要var。

16. for in

遍歷對象的屬性的時候,還會遍歷方法函數(shù),真浪費。加上一個if語句過濾下:

for(key in object) {  
   if(object.hasOwnProperty(key) {  
      ...then do something...  
   }  
}
17. 使用Firebug timer 作性能分析

Firebug timer 可以簡單地確定操作消耗的時間:

function TimeTracker(){  
 console.time("MyTimer");  
 for(x=5000; x > 0; x--){}  
 console.timeEnd("MyTimer");  
}
18. 閱讀,閱讀,還是閱讀

午餐之余或上床睡覺之前,讀點書吧。床頭常發(fā)一本web開發(fā)方面的書。我喜歡讀的一些書包括:

Object-Oriented JavaScript

JavaScript: The Good Parts

Learning jQuery 1.3

Learning JavaScript

讀下吧。多讀幾遍。我常讀。

19. 自執(zhí)行函數(shù)

用括號包裹函數(shù)定義,然后應用函數(shù):

(function doSomething() {  
   return {  
      name: "jeff",  
      lastName: "way"  
   };  
})();

CoffeeScript版本更簡潔:

(-> { name: "jeff", lastName: "way" })()

do的話更清楚:

do -> { name: "jeff", lastName: "way" }
20. 原生代碼總能比使用庫更快

jQuery和Mootools可以節(jié)約你大量的開發(fā)時間——特別是處理AJAX。但是別忘了,使用庫永遠不會比原生代碼快(假定你編碼正確)。


本文為24 JavaScript Best Practices for Beginners的衍生作品,在其基礎上進行了歸并調(diào)整,并加入了 CoffeeScript 的內(nèi)容。

文章版權歸作者所有,未經(jīng)允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉載請注明本文地址:http://systransis.cn/yun/77988.html

相關文章

  • 前端學習資源

    摘要:掘金日報第四期使用怎么能不知道這些插件合集掘金日報主打分享優(yōu)質(zhì)深度技術內(nèi)容,技術內(nèi)容分前端后端產(chǎn)品設計工具資源和一些有趣的東西。目前已經(jīng)涵蓋了的相關資源鏈接,供大家參考與學習。 【掘金日報】第四期 使用Sublime?怎么能不知道這些 Sublime 插件合集! 掘金日報主打分享優(yōu)質(zhì)深度技術內(nèi)容,技術內(nèi)容分:前端、后端、Android、iOS、產(chǎn)品設計、工具資源和一些有趣的東西。 前端...

    xzavier 評論0 收藏0
  • 前端學習資源

    摘要:掘金日報第四期使用怎么能不知道這些插件合集掘金日報主打分享優(yōu)質(zhì)深度技術內(nèi)容,技術內(nèi)容分前端后端產(chǎn)品設計工具資源和一些有趣的東西。目前已經(jīng)涵蓋了的相關資源鏈接,供大家參考與學習。 【掘金日報】第四期 使用Sublime?怎么能不知道這些 Sublime 插件合集! 掘金日報主打分享優(yōu)質(zhì)深度技術內(nèi)容,技術內(nèi)容分:前端、后端、Android、iOS、產(chǎn)品設計、工具資源和一些有趣的東西。 前端...

    weij 評論0 收藏0
  • Webpack 最佳實踐總結(一)

    摘要:它會代替所有的實例的值為,從而使知道那些判斷表達式總是錯誤的,從而刪除相關代碼,進一步壓縮打包文件模塊機制項目中使用的,通過也能通過打包有用的代碼,進一步減少大小。 好久沒寫文章,這次預計會帶來3篇的 Webpack 系列文章,將會在這幾天內(nèi)更新完。 Webpack3 自今年6月20日正式發(fā)布而來,給我們帶來Scope Hoisting和Magic Comments兩大功能,可惜不在這...

    jubincn 評論0 收藏0
  • [ 好文分享 ] jQuery最佳實踐

    摘要:所以,最佳選擇是。事實上,這種處理完全不必要。這樣的設計,使得讀取局部變量比讀取全局變量快得多。請看下面兩段代碼,第一段代碼是讀取全局變量第二段代碼是讀取局部變量第二段代碼讀取變量的時候,不用前往上一層作用域,所以要比第一段代碼快五六倍。 轉自:http://www.ruanyifeng.com/blog/2011/08/jquery_best_practices.html ...

    mzlogin 評論0 收藏0
  • jQuery最佳實踐

    摘要:所以,最佳選擇是。事實上,這種處理完全不必要。這樣的設計,使得讀取局部變量比讀取全局變量快得多。請看下面兩段代碼,第一段代碼是讀取全局變量第二段代碼是讀取局部變量第二段代碼讀取變量的時候,不用前往上一層作用域,所以要比第一段代碼快五六倍。 轉自:阮一峰 日期: 2011年8月 4日http://www.ruanyifeng.com/blo... 上周,我整理了《jQuery設計思想》。...

    senntyou 評論0 收藏0

發(fā)表評論

0條評論

fuchenxuan

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<