Javascript中for循環(huán)語句有哪些寫法-創(chuàng)新互聯(lián)

這篇文章主要介紹了Javascript中for循環(huán)語句有哪些寫法,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

創(chuàng)新互聯(lián)是創(chuàng)新、創(chuàng)意、研發(fā)型一體的綜合型網(wǎng)站建設(shè)公司,自成立以來公司不斷探索創(chuàng)新,始終堅(jiān)持為客戶提供滿意周到的服務(wù),在本地打下了良好的口碑,在過去的十余年時間我們累計(jì)服務(wù)了上千家以及全國政企客戶,如咖啡廳設(shè)計(jì)等企業(yè)單位,完善的項(xiàng)目管理流程,嚴(yán)格把控項(xiàng)目進(jìn)度與質(zhì)量監(jiān)控加上過硬的技術(shù)實(shí)力獲得客戶的一致稱譽(yù)。

一般寫法如下:

for(var i = 0;i< arr.length;i++) {
 var a = arr[i];
 //...
 }

這就是一個常見的,正序循環(huán)的for循環(huán)。這樣寫的缺點(diǎn)大家都明白:每次都從arr里取length與i來對比,浪費(fèi)性能(而且,要是arr的長度是動態(tài)變化的,就會出現(xiàn)死循環(huán))。改進(jìn)這個循環(huán)的辦法是用變量保存arr.length

for(var i = 0, al = arr.length;i< al;i++) {
 var a = arr[i];
 //...
 }

這樣比第一種可以略微提升點(diǎn)性能,要是數(shù)組長,可以提升更多。

不過這樣寫就多了個變量al,且這個變量只在用來與i對比的時候有用,看著有點(diǎn)雞肋。

如果循環(huán)順序?qū)δ悴恢匾悄憧梢試L試倒序循環(huán):

for(var i = arr.length-1;i > -1;i--) {
 var a = arr[i];
 //...
 }

這樣一來變量少些,且還緩存過arr長度,性能也不錯。但這里的代碼寫得有點(diǎn)拙劣(我故意的),首先是i = arr.length-1(居然要-1,靠),然后是循環(huán)繼續(xù)執(zhí)行的條件i > -1,都讓有潔癖的人無法忍受。

下面是我常用的倒序for循環(huán)寫法:

for(var i = arr.length;i--;) {
 var a = arr[i];
 //...
 }

這已經(jīng)非常精簡了。原理需要理解一下:for循環(huán)繼續(xù)執(zhí)行的條件,是;;之間的這個判斷要為真,而這里的i–,在第一次循環(huán)進(jìn)來的時候,i=arr.length,i–值不變(為什么不變?因?yàn)橐趂or循環(huán)體里面,才會發(fā)現(xiàn)i變了);當(dāng)i=1時,i- -還是1,但進(jìn)入循環(huán)體后,就是0了,所以可以正常執(zhí)行最后一次循環(huán);當(dāng)i=0時,i–還是0,而0已經(jīng)不為真了,所以循環(huán)就不會繼續(xù)執(zhí)行了。

大家注意到上面的所有代碼的for循環(huán)體里,都有個var a = arr[i],用來取出當(dāng)前循環(huán)到的數(shù)組項(xiàng)。這實(shí)際上也是種浪費(fèi),且jsLint等會告訴你:不要在循環(huán)里聲明變量。。。

倒序的for可以精簡至斯,但我就是要正序,而且要效率高,變量少,怎么辦?

如下:

for(var i = 0, a;a = arr[i++];) {
 //...
 }

這種寫法好處在于:幾乎不可避免的arr.length不見了,前面說的取出當(dāng)前循環(huán)到的數(shù)組項(xiàng)的那一句也不見了。

原理:

a = arr[i++],在這里作為循環(huán)能執(zhí)行的條件,注意這里只有一個=號,所以這不是判斷句,是賦值語句,就是把arr[i++]賦給a,然后判斷a是不是真值。i++與i–的原理類型我就不說了,只說當(dāng)i++已經(jīng)超過數(shù)組的長度時,循環(huán)肯定要停止才行,而這里真的就停止了,為什么?因?yàn)?code>a=arr[i++],如果取到了超出數(shù)組本身長度的項(xiàng),只會取得一個undefined,而undefined是假值,循環(huán)條件就判斷失敗了。

當(dāng)然,這樣寫的缺點(diǎn)也很明顯:

    1,當(dāng)arr的長度動態(tài)變化時,依然會產(chǎn)生死循環(huán)————因?yàn)槲覀儚膩頉]緩存過arr.length呀。

    2,如果循環(huán)的是一個數(shù)字?jǐn)?shù)組,當(dāng)取出的項(xiàng)(即a的值)為0時,就會中止循環(huán)(因?yàn)?是假值)。

    3,當(dāng)數(shù)組中某一項(xiàng)是假值時(包括空字符串,0,null,undefined),同樣會中止循環(huán)

所以大家用這種寫法時,最好排除掉上面的情況再用。

這個原理同樣可以用在倒序循環(huán)上。

最后我要忠告大家?guī)拙洌?/strong>

  1. 代碼精簡不等于效率高!

  2. 不要為了故意精簡代碼而喪失性能

順帶說幾點(diǎn)提高for循環(huán)性能的要點(diǎn):

    1,適時break!不需要遍歷全部的就要加跳出條件!

    2,不要在for循環(huán)體里聲明變量(建議一次var,多次賦值)

    2,數(shù)組長度緩存,盡量少變量

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“Javascript中for循環(huán)語句有哪些寫法”這篇文章對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián)建站,關(guān)注創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習(xí)!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站muchs.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。

當(dāng)前題目:Javascript中for循環(huán)語句有哪些寫法-創(chuàng)新互聯(lián)
網(wǎng)址分享:http://muchs.cn/article16/egpgg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站排名搜索引擎優(yōu)化、品牌網(wǎng)站制作、小程序開發(fā)、虛擬主機(jī)網(wǎng)頁設(shè)計(jì)公司

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)