- 相關(guān)推薦
客戶端js性能優(yōu)化的小技巧整理
下面是一些關(guān)于客戶端JS性能的一些優(yōu)化的小技巧:
1. 關(guān)于JS的循環(huán),循環(huán)是一種常用的流程控制。JS提供了三種循環(huán):for(;;)、while()、for(in)。在這三種循環(huán)中 for(in)的效率最差,因為它需要查詢Hash鍵,因此應(yīng)盡量少用for(in)循環(huán),for(;;)、while()循環(huán)的性能基本持平。當(dāng)然,推薦使用for循環(huán),如果循環(huán)變量遞增或遞減,不要單獨對循環(huán)變量賦值,而應(yīng)該使用嵌套的++或--運算符。
2. 如果需要遍歷數(shù)組,應(yīng)該先緩存數(shù)組長度var len=arr.length; for(i=0;i<len;i++),將數(shù)組長度放入局部變量中,避免多次查詢數(shù)組長度。
3. 局部變量的訪問速度要比全局變量的訪問速度更快,因為全局變量其實是window對象的成員,而局部變量是放在函數(shù)的棧里的。
4. 盡量少使用eval,每次使用eval需要消耗大量時間,特別是在循環(huán)內(nèi),json[i][變量]=1;這樣的語句可以不使用eval。
5. 盡量避免對象的嵌套查詢,對于obj1.obj2.obj3.obj4這個語句,需要進(jìn)行至少3次查詢操作,先檢查obj1中是否包含 obj2,再檢查obj2中是否包含obj3,然后檢查obj3中是否包含obj4...這不是一個好策略。應(yīng)該盡量利用局部變量,將obj4以局部變量 保存,從而避免嵌套查詢。
6. 使運算符時,盡量使用+=,-=、*=、=等運算符號,而不是直接進(jìn)行賦值運算。
7. 當(dāng)需要將數(shù)字轉(zhuǎn)換成字符時,采用如下方式:"" + 1。從性能上來看,將數(shù)字轉(zhuǎn)換成字符時,有如下公式:("" +) > String() > .toString() > new String()。String()屬于內(nèi)部函數(shù),所以速度很快。而.toString()要查詢原型中的函數(shù),所以速度遜色一些,new String()需要重新創(chuàng)建一個字符串對象,速度最慢。
8. 當(dāng)需要將浮點數(shù)轉(zhuǎn)換成整型時,應(yīng)該使用Math.floor()或者M(jìn)ath.round()。而不是使用parseInt(),該方法用于將字符串轉(zhuǎn)換成數(shù)字。而且Math是內(nèi)部對象,所以Math.floor()其實并沒有多少查詢方法和調(diào)用時間,速度是最快的。
9.盡量作用JSON格式來創(chuàng)建對象,而不是var obj=new Object()方法。因為前者是直接復(fù)制,而后者需要調(diào)用構(gòu)造器,因而前者的性能更好。
10.當(dāng)需要使用數(shù)組時,也盡量使用JSON格式的語法,即直接使用如下語法定義數(shù)組:[parrm,param,param...],而不是采用 new Array(parrm,param,param...)這種語法。因為使用JSON格式的語法是引擎直接解釋的。而后者則需要調(diào)用Array的構(gòu)造器。
11. 對字符串進(jìn)行循環(huán)操作,例如替換、查找,就使用正則表達(dá)式。因為JS的循環(huán)速度比較慢,而正則表達(dá)式的操作是用C寫成的API,性能比較好。
最后有一個基本原則,對于大的JS對象,因為創(chuàng)建時時間和空間的開銷都比較大,因此應(yīng)該盡量考慮采用緩存。
【客戶端js性能優(yōu)化的小技巧整理】相關(guān)文章:
舞蹈的小技巧12-17
保養(yǎng)頭發(fā)的小技巧04-19
女生打籃球的小技巧02-21
整理書桌作文07-22
整理書包作文08-05
整理房間的作文08-06
女人睡前肌膚美容護(hù)理八個小技巧12-14
整理書柜作文07-29
整理書架作文11-23
整理內(nèi)務(wù)作文08-07