|
復制代碼 代碼如下:
var arr = [];
for(var i=0; i<arr.length; i++){
//loop
}
這種代碼最大的問題,就在于每次循環時都要通過 .操作符獲取 .length,增加了開銷。那么我們可以這樣改進。
復制代碼 代碼如下:
var arr = [];
for(var i=0, n=arr.length; i<n; i++){
//loop
}
這樣子,先把 arr.length暫存到 n 變量中去。只在開始時獲取一次。
但是這樣就沒問題了嗎?貌似多定義了個無意義的變量 n 。好那繼續改進
復制代碼 代碼如下:
var arr = [];
for(var i=arr.length-1; i > -1; i--){
//loop
}
好這樣子,我們把這個循環順序倒過來,就把那個n去掉了,而使用了一個常量-1。
如果應用場景,允許不使用 for 循環的話。我們可在使用 while代替
善于使用這兩種循環語句,以提高Javascript的效率。
復制代碼 代碼如下:
var arr = [];
var i=arr.length-1;
while(i--){
//loop arr[i]
}
或者
復制代碼 代碼如下:
var arr = [];
var i=arr.length-1;
do {
// loop arr[i]
}while(--i)
這樣代碼更簡潔,效率更好,特別是如果允許先執行一次循環體的情況下,使用do while效果很明顯。
唯一的問題是把 i 移到循環外了。
JavaScript技術:javascript for循環設法提高性能,轉載需保留來源!
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。