JavaScript性能優(yōu)化小竅門實例匯總

JavaScript性能優(yōu)化小竅門實例匯總

在眾多語言中,JavaScript已經(jīng)占有重要的一席之地胞枕,利用JavaScript我們可以做很多事情 腐泻, 應用廣泛派桩。

在web應用項目中铆惑,需要大量JavaScript的代碼员魏,將來也會越來越多撕阎。

但是由于JavaScript是一個作為解釋執(zhí)行的語言,而且它的單線程機制脑慧,決定了性能問題是JavaScript的弱點闷袒,也是開發(fā)者在寫JavaScript的時候需注意的一個問題囊骤。

因為經(jīng)常會遇到Web 2.0應用性能欠佳的問題冀值,主因就是JavaScript性能不足列疗,導致瀏覽器負荷過重。 Javascript性能優(yōu)化絕不是一種書面的技能坤次,那么應該如何正確的加載和執(zhí)行 JavaScript代碼缰猴,從而提高其在瀏覽器中的性能呢滑绒?下面就給大家做一些優(yōu)化小竅門的知識匯總蹬挤。

無論當前 JavaScript 代碼是內(nèi)嵌還是在外鏈文件中焰扳,頁面的下載和渲染都必須停下來等待腳本執(zhí)行完成吨悍。JavaScript 執(zhí)行過程耗時越久育瓜,瀏覽器等待響應用戶輸入的時間就越長躏仇。

瀏覽器在下載和執(zhí)行腳本時出現(xiàn)阻塞的原因在于焰手,腳本可能會改變頁面或JavaScript的命名空間书妻,它們會對后面頁面內(nèi)容造成影響躲履。一個典型的例子就是在頁面中使用:

document.write()

示例:

<html><head>

<title>Source Example</title></head><body>

<p>

<script type="text/javascript">

document.write("Today is " + (new Date()).toDateString()); </script>

</p></body></html>

當瀏覽器遇到<script>標簽時工猜,當前 HTML 頁面無從獲知 JavaScript 是否會向<p> 標簽添加內(nèi)容域慷,或引入其他元素犹褒,或甚至移除該標簽叠骑。

因此宙枷,這時瀏覽器會停止處理頁面慰丛,先執(zhí)行 JavaScript代碼诅病,然后再繼續(xù)解析和渲染頁面贤笆。

同樣的情況也發(fā)生在使用 src 屬性加載 JavaScript的過程中芥永,瀏覽器必須先花時間下載外鏈文件中的代碼埋涧,然后解析并執(zhí)行它棘催。在這個過程中巧鸭,頁面渲染和用戶交互完全被阻塞了纲仍。

不要使用 with() 語句

這是因為 with() 語句將會在作用域鏈的開始添加額外的變量郑叠。額外的變量意味著乡革,當任何變量需要被訪問的時候沸版,JavaScript引擎都需要先掃描with()語句產(chǎn)生的變量视粮,然后才是局部變量蕾殴,最后是全局變量钓觉。

因此with()語句同時給局部變量和全局變量的性能帶來負面影響瓤狐,最終使我們優(yōu)化JavaScript性能的計劃破產(chǎn)芬首。

對象屬性和數(shù)組元素的速度都比變量慢

談到JavaScript的數(shù)據(jù)郁稍,一般來說有4種訪問方式:數(shù)值胜宇、變量耀怜、對象屬性和數(shù)組元素。在考慮優(yōu)化時桐愉,數(shù)值和變量的性能差不多财破,并且速度顯著優(yōu)于對象屬性和數(shù)組元素。

因此當你多次引用一個對象屬性或者數(shù)組元素的時候从诲,你可以通過定義一個變量來獲得性能提升左痢。(這一條在讀系洛、寫數(shù)據(jù)時都有效)雖然這條規(guī)則在絕大多數(shù)情況下是正確的俊性,但是Firefox在優(yōu)化數(shù)組索引上做了一些有意思的工作,能夠讓它的實際性能優(yōu)于變量描扯。

但是考慮到數(shù)組元素在其他瀏覽器上的性能弊端定页,還是應該盡量避免數(shù)組查找,除非你真的只針對于火狐瀏覽器的性能而進行開發(fā)绽诚。

避免全局查找

在一個函數(shù)中會用到全局對象存儲為局部變量來減少全局查找典徊,因為訪問局部變量的速度要比訪問全局變量的速度更快些

function search() {

//當我要使用當前頁面地址和主機域名

alert(window.location.href + window.location.host);

}

//最好的方式是如下這樣 先用一個簡單變量保存起來

function search() {

var location = window.location;

alert(location.href + location.host);

}

避免with語句

和函數(shù)類似 杭煎,with語句會創(chuàng)建自己的作用域,因此會增加其中執(zhí)行的代碼的作用域鏈的長度卒落,由于額外的作用域鏈的查找羡铲,在with語句中執(zhí)行的代碼肯定會比外面執(zhí)行的代碼要慢,在能不使用with語句的時候盡量不要使用with語句儡毕。

with (a.b.c.d) {

property1 = 1;

property2 = 2;

} //可以替換為:

var obj = a.b.c.d;

obj.property1 = 1;

obj.property2 = 2;

數(shù)字轉(zhuǎn)換成字符串

般最好用”" + 1來將數(shù)字轉(zhuǎn)換成字符串犀勒,雖然看起來比較丑一點,但事實上這個效率是最高的妥曲,性能上來說:

(“” +) > String() > .toString() > new String()

通過模板元素clone贾费,替代createElement

很多人喜歡在JavaScript中使用document.write來給頁面生成內(nèi)容。事實上這樣的效率較低檐盟,如果需要直接插入HTML褂萧,可以找一個容器元素,比如指定一個div或者span葵萎,并設置他們的innerHTML來將自己的HTML代碼插入到頁面中导犹。

通常我們可能會使用字符串直接寫HTML來創(chuàng)建節(jié)點,其實這樣做羡忘,1:無法保證代碼的有效性谎痢,2:字符串操作效率低,所以應該是用document.createElement()方法卷雕,而如果文檔中存在現(xiàn)成的樣板節(jié)點节猿,應該是用cloneNode()方法,因為使用createElement()方法之后漫雕,你需要設置多次元素的屬性滨嘱,使用cloneNode()則可以減少屬性的設置次數(shù)——同樣如果需要創(chuàng)建很多元素,應該先準備一個樣板節(jié)點浸间。

var frag = document.createDocumentFragment();

for (var i = 0; i < 1000; i++) {

var el = document.createElement('p');

el.innerHTML = i;

frag.appendChild(el);

} document.body.appendChild(frag);

//替換為:

var frag = document.createDocumentFragment(); var pEl = document.getElementsByTagName('p')[0];

for (var i = 0; i < 1000; i++) {

var el = pEl.cloneNode(false);

el.innerHTML = i;

frag.appendChild(el);

} document.body.appendChild(frag);

避免低效率的腳本位置

HTML 4 規(guī)范指出 <script> 標簽可以放在 HTML 文檔的<head>或<body>中太雨,并允許出現(xiàn)多次。Web 開發(fā)人員一般習慣在 <head> 中加載外鏈的 JavaScript魁蒜,接著用 <link> 標簽用來加載外鏈的 CSS 文件或者其他頁面信息囊扳。

低效率腳本位置示例:

<html><head>

<title>Source Example</title>

<script type="text/javascript" src="script1.js"></script>

<script type="text/javascript" src="script2.js"></script>

<script type="text/javascript" src="script3.js"></script>

<link rel="stylesheet" type="text/css" href="styles.css"></head><body>

<p>Hello world!</p></body></html>

然而這種常規(guī)的做法卻隱藏著嚴重的性能問題。

在清單 2 的示例中兜看,當瀏覽器解析到 <script> 標簽(第 4 行)時锥咸,瀏覽器會停止解析其后的內(nèi)容,而優(yōu)先下載腳本文件铣减,并執(zhí)行其中的代碼她君,這意味著脚作,其后的 styles.css 樣式文件和<body>標簽都無法被加載葫哗,由于<body>標簽無法被加載缔刹,那么頁面自然就無法渲染了。

因此在該 JavaScript 代碼完全執(zhí)行完之前劣针,頁面都是一片空白校镐。下圖描述了頁面加載過程中腳本和樣式文件的下載過程。

我們可以發(fā)現(xiàn)一個有趣的現(xiàn)象:第一個 JavaScript 文件開始下載捺典,與此同時阻塞了頁面其他文件的下載鸟廓。

此外,從 script1.js 下載完成到 script2.js 開始下載前存在一個延時襟己,這段時間正好是 script1.js 文件的執(zhí)行過程引谜。每個文件必須等到前一個文件下載并執(zhí)行完成才會開始下載。在這些文件逐個下載過程中擎浴,用戶看到的是一片空白的頁面员咽。

從 IE 8、Firefox 3.5贮预、Safari 4 和 Chrome 2 開始都允許并行下載 JavaScript 文件贝室。這是個好消息,因為<script>標簽在下載外部資源時不會阻塞其他<script>標簽仿吞。遺憾的是滑频,JavaScript 下載過程仍然會阻塞其他資源的下載,比如樣式文件和圖片唤冈。

盡管腳本的下載過程不會互相影響峡迷,但頁面仍然必須等待所有 JavaScript 代碼下載并執(zhí)行完成才能繼續(xù)。因此你虹,盡管最新的瀏覽器通過允許并行下載提高了性能凉当,但問題尚未完全解決,腳本阻塞仍然是一個問題售葡。

由于腳本會阻塞頁面其他資源的下載看杭,因此推薦將所有<script>標簽盡可能放到<body>標簽的底部,以盡量減少對整個頁面下載的影響挟伙。

推薦的代碼放置位置示例:

<head>

<title>Source Example</title>

<link rel="stylesheet" type="text/css" href="styles.css"></head><body>

<p>Hello world!</p>

<!-- Example of efficient script positioning -->

<script type="text/javascript" src="script1.js"></script>

<script type="text/javascript" src="script2.js"></script>

<script type="text/javascript" src="script3.js"></script></body></html>

這段代碼展示了在 HTML 文檔中放置<script>標簽的推薦位置楼雹。盡管腳本下載會阻塞另一個腳本,但是頁面的大部分內(nèi)容都已經(jīng)下載完成并顯示給了用戶尖阔,因此頁面下載不會顯得太慢贮缅。

這是優(yōu)化 JavaScript 的首要規(guī)則:將腳本放在底部。

小心使用閉包

雖然你可能還不知道“閉包”介却,但你可能在不經(jīng)意間經(jīng)常使用這項技術谴供。閉包基本上被認為是JavaScript中的new,當我們定義一個即時函數(shù)的時候齿坷,我們就使用了閉包桂肌,比如:

document.getElementById('foo').onclick = function(ev) { };

閉包的問題在于:根據(jù)定義数焊,在它們的作用域鏈中至少有三個對象:閉包變量、局部變量和全局變量崎场。這些額外的對象將會導致其他的性能問題佩耳。但是Nicholas并不是要我們因噎廢食,閉包對于提高代碼可讀性等方面還是非常有用的谭跨,只是不要濫用它們(尤其在循環(huán)中)干厚。

在循環(huán)時將控制條件和控制變量合并起來

提到性能,在循環(huán)中需要避免的工作一直是個熱門話題螃宙,因為循環(huán)會被重復執(zhí)行很多次蛮瞄。所以如果有性能優(yōu)化的需求,先對循環(huán)開刀有可能會獲得最明顯的性能提升谆扎。

一種優(yōu)化循環(huán)的方法是在定義循環(huán)的時候裕坊,將控制條件和控制變量合并起來,下面是一個沒有將他們合并起來的例子:

for ( var x = 0; x < 10; x++ ) {

};

當我們要添加什么東西到這個循環(huán)之前燕酷,我們發(fā)現(xiàn)有幾個操作在每次迭代都會出現(xiàn)籍凝。JavaScript引擎需要:

#1:檢查 x 是否存在#2:檢查 x 是否小于 0 <span style="color: #888888;">(這里可能有筆誤)</span>#3:使 x 增加 1

然而如果你只是迭代元素中的一些元素,那么你可以使用while循環(huán)進行輪轉(zhuǎn)來替代上面這種操作:

var x = 9;do { } while( x-- );

使用 XMLHttpRequest(XHR)對象

此技術首先創(chuàng)建一個 XHR 對象苗缩,然后下載 JavaScript 文件饵蒂,接著用一個動態(tài)<script>元素將 JavaScript 代碼注入頁面。

通過 XHR 對象加載 JavaScript 腳本:

var xhr = new XMLHttpRequest();

xhr.open("get", "script1.js", true);

xhr.onreadystatechange = function(){

if (xhr.readyState == 4){

if (xhr.status >= 200 && xhr.status < 300 || xhr.status == 304){

var script = document.createElement ("script");

script.type = "text/javascript";

script.text = xhr.responseText; document.body.appendChild(script);

}

}

};

xhr.send(null);

此代碼向服務器發(fā)送一個獲取 script1.js 文件的 GET 請求酱讶。onreadystatechange 事件處理函數(shù)檢查readyState 是不是 4退盯,然后檢查 HTTP 狀態(tài)碼是不是有效(2XX 表示有效的回應,304 表示一個緩存響應)泻肯。

如果收到了一個有效的響應渊迁,那么就創(chuàng)建一個新的<script>元素,將它的文本屬性設置為從服務器接收到的 responseText 字符串灶挟。

這樣做實際上會創(chuàng)建一個帶有內(nèi)聯(lián)代碼的<script>元素琉朽。一旦新<script>元素被添加到文檔,代碼將被執(zhí)行稚铣,并準備使用箱叁。

這種方法的主要優(yōu)點是,您可以下載不立即執(zhí)行的 JavaScript 代碼惕医。由于代碼返回在<script>標簽之外(換句話說不受<script>標簽約束)耕漱,它下載后不會自動執(zhí)行,這使得您可以推遲執(zhí)行抬伺,直到一切都準備好了螟够。

另一個優(yōu)點是,同樣的代碼在所有現(xiàn)代瀏覽器中都不會引發(fā)異常峡钓。

此方法最主要的限制是:JavaScript 文件必須與頁面放置在同一個域內(nèi)妓笙,不能從 CDN 下載(CDN 指”內(nèi)容投遞網(wǎng)絡(Content Delivery Network)”若河,所以大型網(wǎng)頁通常不采用 XHR 腳本注入技術。

注意NodeList

最小化訪問NodeList的次數(shù)可以極大的改進腳本的性能

var images = document.getElementsByTagName('img'); for (var i = 0, len = images.length;

i < len; i++) {

}

編寫JavaScript的時候一定要知道何時返回NodeList對象给郊,這樣可以最小化對它們的訪問。

1捧灰、進行了對getElementsByTagName()的調(diào)用

2淆九、獲取了元素的childNodes屬性

3、獲取了元素的attributes屬性

4毛俏、訪問了特殊的集合炭庙,如document.forms、document.images等等

要了解了當使用NodeList對象時煌寇,合理使用會極大的提升代碼執(zhí)行速度

避免與null進行比較

由于JavaScript是弱類型的焕蹄,所以它不會做任何的自動類型檢查,所以如果看到與null進行比較的代碼阀溶,嘗試使用以下技術替換:

1腻脏、如果值應為一個引用類型,使用instanceof操作符檢查其構造函數(shù)

2银锻、如果值應為一個基本類型永品,作用typeof檢查其類型

3、如果是希望對象包含某個特定的方法名击纬,則使用typeof操作符確保指定名字的方法存在于對象上

尊重對象的所有權

因為JavaScript可以在任何時候修改任意對象鼎姐,這樣就可以以不可預計的方式覆寫默認的行為,所以如果你不負責維護某個對象更振,它的對象或者它的方法炕桨,那么你就不要對它進行修改,具體一點就是說:

1肯腕、不要為實例或原型添加屬性

2献宫、不要為實例或者原型添加方法

3、不要重定義已經(jīng)存在的方法

4实撒、不要重復定義其它團隊成員已經(jīng)實現(xiàn)的方法遵蚜,永遠不要修改不是由你所有的對象,你可以通過以下方式為對象創(chuàng)建新的功能:

01奈惑、創(chuàng)建包含所需功能的新對象吭净,并用它與相關對象進行交互

02、創(chuàng)建自定義類型肴甸,繼承需要進行修改的類型寂殉,然后可以為自定義類型添加額外功能

循環(huán)引用

如果循環(huán)引用中包含DOM對象或者ActiveX對象,那么就會發(fā)生內(nèi)存泄露原在。

內(nèi)存泄露的后果是在瀏覽器關閉前友扰,即使是刷新頁面彤叉,這部分內(nèi)存不會被瀏覽器釋放。

簡單的循環(huán)引用:

var el = document.getElementById('MyElement');

var func = function () {

//…

}

el.func = func;

func.element = el;

但是通常不會出現(xiàn)這種情況村怪。通常循環(huán)引用發(fā)生在為dom元素添加閉包作為expendo的時候秽浇。

function init() {

var el = document.getElementById('MyElement');

el.onclick = function () {

//……

}

}

init();

init在執(zhí)行的時候,當前上下文我們叫做context甚负。這個時候柬焕,context引用了el,el引用了function梭域,function引用了context斑举。這時候形成了一個循環(huán)引用。

下面2種方法可以解決循環(huán)引用:

1病涨、置空dom對象

function init() {

var el = document.getElementById('MyElement');

el.onclick = function () {

//……

}

}

init();

//可以替換為:

function init() {

var el = document.getElementById('MyElement');

el.onclick = function () {

//……

}

el = null;

}

init();

將el置空富玷,context中不包含對dom對象的引用,從而打斷循環(huán)應用既穆。

如果我們需要將dom對象返回赎懦,可以用如下方法:

function init() {

var el = document.getElementById('MyElement');

el.onclick = function () {

//……

} return el;

}

init();

//可以替換為:

function init() {

var el = document.getElementById('MyElement');

el.onclick = function () {

//……

} try {

return el;

} finally {

el = null;

}

}

init();

2、構造新的context

function init() {

var el = document.getElementById('MyElement');

el.onclick = function () {

//……

}

}

init();

//可以替換為:

function elClickHandler() {

//……

} function init() { var el = document.getElementById('MyElement');

el.onclick = elClickHandler;

}

init();

把function抽到新的context中幻工,這樣铲敛,function的context就不包含對el的引用,從而打斷循環(huán)引用会钝。

通過javascript創(chuàng)建的dom對象伐蒋,必須append到頁面中

IE下,腳本創(chuàng)建的dom對象迁酸,如果沒有append到頁面中先鱼,刷新頁面,這部分內(nèi)存是不會回收的奸鬓!

function create() {

var gc = document.getElementById('GC'); for (var i = 0; i < 5000; i++) {

var el = document.createElement('div');

el.innerHTML = "test";

//下面這句可以注釋掉焙畔,

看看瀏覽器在任務管理器中,

點擊按鈕然后刷新后的內(nèi)存變化

gc.appendChild(el);

}

}

字符串連接

如果要連接多個字符串串远,應該少使用+=宏多,如

s+=a;

s+=b;

s+=c;

應該寫成

s+=a + b + c;

而如果是收集字符串澡罚,比如多次對同一個字符串進行+=操作的話伸但,最好使用一個緩存,使用JavaScript數(shù)組來收集留搔,最后使用join方法連接起來

var buf = [];

for (var i = 0; i < 100; i++) { buf.push(i.toString());

} var all = buf.join("");

各種類型轉(zhuǎn)換

var myVar = "3.14159",

str = "" + myVar, // to string

i_int = ~ ~myVar, // to integer

f_float = 1 * myVar, // to float

b_bool = !!myVar, /* to boolean - any string with length

and any number except 0 are true */

array = [myVar]; // to array

如果定義了toString()方法來進行類型轉(zhuǎn)換的話更胖,推薦 顯式調(diào)用toString() ,因為內(nèi)部的操作在嘗試所有可能性之后,會嘗試對象的toString()方法嘗試能否轉(zhuǎn)化為String却妨,所以直接調(diào)用這個方法效率會更高饵逐。

多個類型聲明

在JavaScript中所有變量都可以使用單個var語句來聲明,這樣就是組合在一起的語句彪标,以減少整個腳本的執(zhí)行時間倍权,就如上面代碼一樣,上面代碼格式也挺規(guī)范捞烟,讓人一看就明了薄声。

插入迭代器

如var name=values[i]; i++;前面兩條語句可以寫成var name=values[i++]。

使用直接量

var aTest = new Array(); //替換為

var aTest = [];

var aTest = new Object; //替換為

var aTest = {};

var reg = new RegExp(); //替換為

var reg = /../;

//如果要創(chuàng)建具有一些特性的一般對象坷襟,也可以使用字面量奸柬,如下:

var oFruit = new O;

oFruit.color = "red";

oFruit.name = "apple";

//前面的代碼可用對象字面量來改寫成這樣:

var oFruit = { color: "red", name: "apple" };

避免雙重解釋

如果要提高代碼性能生年,盡可能避免出現(xiàn)需要按照JavaScript解釋的字符串婴程,也就是

1、盡量少使用eval函數(shù)

使用eval相當于在運行時再次調(diào)用解釋引擎對內(nèi)容進行運行抱婉,需要消耗大量時間档叔,而且使用Eval帶來的安全性問題也是不容忽視的。

2蒸绩、不要使用Function構造器

不要給setTimeout或者setInterval傳遞字符串參數(shù)

var num = 0;

setTimeout('num++', 10);

//可以替換為:

var num = 0;

function addNum() {

num++;

}

setTimeout(addNum, 10);

縮短否定檢測

if (oTest != '#ff0000') {

//do something

}

if (oTest != null) {

//do something

}

if (oTest != false) {

//do something

}

//雖然這些都正確衙四,但用邏輯非操作符來操作也有同樣的效果:

if (!oTest) {

//do something

}

釋放javascript對象

在rich應用中,隨著實例化對象數(shù)量的增加患亿,內(nèi)存消耗會越來越大传蹈。所以應當及時釋放對對象的引用,讓GC能夠回收這些內(nèi)存控件步藕。

對象:obj = null

對象屬性:delete obj.myproperty

數(shù)組item:使用數(shù)組的splice方法釋放數(shù)組中不用的item

性能方面的注意事項

1惦界、盡量使用原生方法

2、switch語句相對if較快

通過將case語句按照最可能到最不可能的順序進行組織咙冗。

3沾歪、位運算較快

當進行數(shù)字運算時,位運算操作要比任何布爾運算或者算數(shù)運算快雾消。

4灾搏、巧用||和&&布爾運算符

function eventHandler(e) {

if (!e) e = window.event;

}

//可以替換為:

function eventHandler(e) {

e = e || window.event;

}

if (myobj) {

doSomething(myobj);

}

//可以替換為:

myobj && doSomething(myobj);

避免錯誤應注意的地方

1、每條語句末尾須加分號

在if語句中立润,即使條件表達式只有一條語句也要用{}把它括起來狂窑,以免后續(xù)如果添加了語句之后造成邏輯錯誤。

2桑腮、使用+號時需謹慎

JavaScript 和其他編程語言不同的是蕾域,在 JavaScript 中,’+'除了表示數(shù)字值相加,字符串相連接以外旨巷,還可以作一元運算符用巨缘,把字符串轉(zhuǎn)換為數(shù)字。因而如果使用不當采呐,則可能與自增符’++’混淆而引起計算錯誤若锁。

var valueA = 20;

var valueB = "10";

alert(valueA + valueB); //ouput: 2010

alert(valueA + (+valueB)); //output: 30

alert(valueA + +valueB); //output:30

alert(valueA ++ valueB); //Compile error

3、使用return語句需要注意

一條有返回值的return語句不要用()括號來括住返回值斧吐,如果返回表達式又固,則表達式應與return關鍵字在同一行,以避免壓縮時煤率,壓縮工具自動加分號而造成返回與開發(fā)人員不一致的結(jié)果仰冠。

function F1() {

var valueA = 1;

var valueB = 2;

return valueA + valueB;

}

function F2() {

var valueA = 1;

var valueB = 2;

return

valueA + valueB;

}

alert(F1()); //output: 3

alert(F2()); //ouput: undefined

==和===的區(qū)別

避免在if和while語句的條件部分進行賦值,如if (a = b)蝶糯,應該寫成if (a == b)洋只,但是在比較是否相等的情況下,最好使用全等運行符昼捍,也就是使用===和!==操作符會相對于==和!=會好點识虚。==和!=操作符會進行類型強制轉(zhuǎn)換。

var valueA = "1";

var valueB = 1;

if (valueA == valueB) {

alert("Equal");

}

else {

alert("Not equal");

}

//output: "Equal"

if (valueA === valueB) {

alert("Equal");

}

else {

alert("Not equal");

}

//output: "Not equal"

不要使用生偏語法

不要使用生偏語法妒茬,寫讓人迷惑的代碼担锤,雖然計算機能夠正確識別并運行,但是晦澀難懂的代碼不方便以后維護乍钻。

函數(shù)返回統(tǒng)一類型

雖然JavaScript是弱類型的肛循,對于函數(shù)來說,前面返回整數(shù)型數(shù)據(jù)银择,后面返回布爾值在編譯和運行都可以正常通過多糠,但為了規(guī)范和以后維護時容易理解,應保證函數(shù)應返回統(tǒng)一的數(shù)據(jù)類型欢摄。

總是檢查數(shù)據(jù)類型

要檢查你的方法輸入的所有數(shù)據(jù)熬丧,一方面是為了安全性,另一方面也是為了可用性怀挠。用戶隨時隨地都會輸入錯誤的數(shù)據(jù)析蝴。這不是因為他們蠢,而是因為他們很忙绿淋,并且思考的方式跟你不同闷畸。用typeof方法來檢測你的function接受的輸入是否合法。

何時用單引號吞滞,何時用雙引號

雖然在JavaScript當中佑菩,雙引號和單引號都可以表示字符串, 為了避免混亂盾沫,我們建議在HTML中使用雙引號,在JavaScript中使用單引號殿漠,但為了兼容各個瀏覽器赴精,也為了解析時不會出錯,定義JSON對象時绞幌,最好使用雙引號蕾哟。

部署

1、用JSLint運行JavaScript驗證器來確保沒有語法錯誤或者是代碼沒有潛在的問

2莲蜘、部署之前推薦使用壓縮工具將JS文件壓縮

3谭确、文件編碼統(tǒng)一用UTF-8

4、JavaScript 程序應該盡量放在 .js 的文件中票渠,需要調(diào)用的時候在 HTML 中以 <script src=”filename.js”> 的形式包含進來逐哈。

JavaScript 代碼若不是該 HTML 文件所專用的,則應盡量避免在 HTML 文件中直接編寫 JavaScript 代碼问顷。因為這樣會大大增加 HTML 文件的大小昂秃,無益于代碼的壓縮和緩存的使用。另外择诈,<script src=”filename.js”> 標簽應盡量放在文件的后面,最好是放在</body>標簽前械蹋。

這樣會降低因加載 JavaScript 代碼而影響頁面中其它組件的加載時間出皇。

?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末羞芍,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子郊艘,更是在濱河造成了極大的恐慌荷科,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,042評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件纱注,死亡現(xiàn)場離奇詭異畏浆,居然都是意外死亡,警方通過查閱死者的電腦和手機狞贱,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,996評論 2 384
  • 文/潘曉璐 我一進店門刻获,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人瞎嬉,你說我怎么就攤上這事蝎毡。” “怎么了氧枣?”我有些...
    開封第一講書人閱讀 156,674評論 0 345
  • 文/不壞的土叔 我叫張陵沐兵,是天一觀的道長。 經(jīng)常有香客問我便监,道長扎谎,這世上最難降的妖魔是什么碳想? 我笑而不...
    開封第一講書人閱讀 56,340評論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮毁靶,結(jié)果婚禮上胧奔,老公的妹妹穿的比我還像新娘。我一直安慰自己预吆,他們只是感情好葡盗,可當我...
    茶點故事閱讀 65,404評論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著啡浊,像睡著了一般觅够。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,749評論 1 289
  • 那天碉就,我揣著相機與錄音翘鸭,去河邊找鬼。 笑死窘拯,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的坝茎。 我是一名探鬼主播涤姊,決...
    沈念sama閱讀 38,902評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼嗤放!你這毒婦竟也來了思喊?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,662評論 0 266
  • 序言:老撾萬榮一對情侶失蹤次酌,失蹤者是張志新(化名)和其女友劉穎恨课,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體岳服,經(jīng)...
    沈念sama閱讀 44,110評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡剂公,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了吊宋。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片纲辽。...
    茶點故事閱讀 38,577評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖璃搜,靈堂內(nèi)的尸體忽然破棺而出拖吼,到底是詐尸還是另有隱情,我是刑警寧澤腺劣,帶...
    沈念sama閱讀 34,258評論 4 328
  • 正文 年R本政府宣布绿贞,位于F島的核電站,受9級特大地震影響橘原,放射性物質(zhì)發(fā)生泄漏籍铁。R本人自食惡果不足惜涡上,卻給世界環(huán)境...
    茶點故事閱讀 39,848評論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望拒名。 院中可真熱鬧吩愧,春花似錦、人聲如沸增显。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,726評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽同云。三九已至糖权,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間炸站,已是汗流浹背星澳。 一陣腳步聲響...
    開封第一講書人閱讀 31,952評論 1 264
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留旱易,地道東北人禁偎。 一個月前我還...
    沈念sama閱讀 46,271評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像阀坏,于是被迫代替她去往敵國和親如暖。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,452評論 2 348

推薦閱讀更多精彩內(nèi)容