在JavaScript中使用for循環(huán)的方法
前言
循環(huán)允許我們通過循環(huán)數(shù)組或?qū)ο笾械捻棽⒆鲆恍┦虑?,比如說打印它們,修改它們,或執(zhí)行其他類型的任務(wù)或動作。JavaScript有各種各樣的循環(huán),for
循環(huán)允許我們對一個集合(如數(shù)組)進(jìn)行迭代。
在這篇文章中,我們將了解JavaScript提供的for
循環(huán)。我們將看看for...in
循環(huán)語句是如何在JavaScript中使用的,它的語法,它如何工作的例子,何時使用它或避免它,以及我們可以使用哪些其他類型的循環(huán)來代替。
為什么使用for循環(huán)
在JavaScript中,就像在其他編程語言中一樣,我們使用循環(huán)來讀取或訪問集合中的項。這個集合可以是一個數(shù)組或一個對象。每當(dāng)循環(huán)語句在一個集合中的項中循環(huán)時,我們稱之為一個迭代。
有兩種方式可以訪問集合中的項。第一種方式是通過它在集合中的鍵,也就是數(shù)組中的索引或?qū)ο笾械膶傩?。第二種方式是通過集合項本身,而不需要鍵。
for…in循環(huán)的定義
JavaScript的for
循環(huán)會或迭代集合中的鍵。使用這些鍵,你就可以訪問它在集合中代表的項。
集合的項可以是數(shù)組,也可以是對象,甚至可以是字符串。
for…in循環(huán)的語法
for
循環(huán)具有以下語法或結(jié)構(gòu):
for (let key in value) { //do something here }
在上述代碼塊中,value
是我們迭代的項的集合。它可以是對象、數(shù)組、字符串等等。key
會是value
每一項的鍵,在每次迭代中都會改變到列表中的下一個鍵。
注意,這里我們使用let
或const
來聲明key
。
在對象中使用for…in循環(huán)
在JavaScript中使用for...in
循環(huán)迭代對象時,其迭代的鍵或者屬性是對象自己的屬性(在上面的示例中,由key
變量表示)。
由于對象可能通過原型鏈繼承數(shù)據(jù)項,其中包括對象的默認(rèn)方法和屬性,以及我們可能定義的對象原型,因此我們應(yīng)該使用hasOwnProperty
。
在下面的例子中,我們通過變量obj
進(jìn)行循環(huán),并打印每一個屬性和值:
const obj = { "a": "JavaScript", 1: "PHP", "b": "Python", 2: "Java" }; for (let key in obj) { console.log(key + ": " + obj[key] ) } // Output: // "1: PHP" // "2: Java" // "a: JavaScript" // "b: Python"
請注意,鍵的迭代順序是升序的(也就是說,從數(shù)字開始,按數(shù)字的順序,然后是字母,按字母的順序)。然而,這個輸出的順序與初始化對象時創(chuàng)建的項的索引順序不同。
在數(shù)組中使用for…in循環(huán)
在JavaScript中使用for...in
循環(huán)來迭代數(shù)組時,在這種情況下,key
將是元素的索引。然而,索引可以按隨機順序迭代。
因此,如果我們上面展示的for...in
循環(huán)語法結(jié)構(gòu)中的value
變量是一個包含五項的數(shù)組,那么key
就不能保證是0到4。一些索引可能會在其他索引之前。關(guān)于何時可能發(fā)生這種情況的細(xì)節(jié)將在本文后面解釋。
在下面的例子中,我們對arr
變量進(jìn)行循環(huán):
const arr = ["JavaScript", "PHP", "Python", "Java"]; for (let key in arr) { console.log(key + ": " + arr[key]) } // Output: // "0: JavaScript" // "1: PHP" // "2: Python" // "3: Java"
在循環(huán)中,我們呈現(xiàn)每個數(shù)組元素的索引和值。
在字符串中使用for…in循環(huán)
你可以在JavaScript中使用for…in
循環(huán)來循環(huán)字符串。然而,不推薦這么做,因為你將在字符串的索引上循環(huán),而不是字符串本身。
在下面的例子中,我們對str
變量進(jìn)行循環(huán):
const str = "Hello!"; for (let key in str) { console.log(key + ": " + str.charAt(key)); } //Output // "0: H" // "1: e" // "2: l" // "3: l" // "4: o" // "5: !"
在這個循環(huán)中,我們要呈現(xiàn)每個字符的鍵或索引,以及該索引的字符。
讓我們看看JavaScript for…in
循環(huán)最適合的情況。
使用for…in循環(huán)迭代對象
因為for...in
循環(huán)只迭代對象的可枚舉屬性,也就是對象自有屬性,而不是像toString
這樣屬于對象原型的屬性。所以使用for...in
循環(huán)來迭代對象是很好的。for...in
循環(huán)提供了一個簡單的方法來迭代一個對象的屬性并最終得到它的值。
使用for…in循環(huán)調(diào)試
JavaScript for...in
循環(huán)的另一個很好的用例是調(diào)試。比如,你可能想向控制臺或HTML元素打印一個對象的屬性和它的值。在這種情況下,for...in
循環(huán)是一個不錯的選擇。
當(dāng)使用for…in
循環(huán)調(diào)試對象以及對象的值時,你應(yīng)該始終記住,迭代是沒有順序的。也就是說,迭代的順序是隨機的。所以,訪問屬性的順序可能與預(yù)期不同。
不使用for…in循環(huán)的情形
現(xiàn)在讓我們來看看for...in
循環(huán)不是最佳選擇的情況。
數(shù)組的有序迭代
由于使用for...in
循環(huán)時不能保證迭代中的索引順序,如果有必要保持順序,建議不要迭代數(shù)組。
如果你想支持像IE這樣的瀏覽器,這一點尤其重要,因為IE是按照數(shù)組項創(chuàng)建的順序而不是按照索引的順序進(jìn)行迭代的。這與當(dāng)前現(xiàn)代瀏覽器的工作方式不同,后者是根據(jù)索引的升序來迭代數(shù)組的。
舉例來說,如果你有一個包含四項的數(shù)組,你在索引3的位置插入了一項,在現(xiàn)代瀏覽器中,for...in
循環(huán)仍然會按照從0到4的順序遍歷數(shù)組。 在IE中,當(dāng)使用for...in
循環(huán)時,它將遍歷一開始就在數(shù)組中的四個項目,然后再遍歷在索引3的位置添加的那一項。
迭代時進(jìn)行更改
對屬性的任何添加、刪除或修改都不能保證有序的迭代。應(yīng)該避免在for...in
循環(huán)中對屬性進(jìn)行更改。這主要是由于它的無序性。
因此,如果你在迭代到達(dá)某一項之前刪除它,那么這項在整個循環(huán)中根本就不會被訪問。
同樣地,如果你對一個屬性進(jìn)行修改,并不能保證這項不會被再次訪問。因此,如果一個屬性被改變,它可能會在循環(huán)中被訪問兩次而不是一次。
除此之外,如果一個屬性在迭代過程中被添加,那么它在迭代過程中可能會被訪問,也可能根本不會被訪問。
由于這些情況,最好避免在for...in
循環(huán)中對一個對象進(jìn)行任何修改、刪除或添加。
下面是一個在for...in
循環(huán)中添加元素的例子。我們可以看到第一個循環(huán)的結(jié)果,然后是在第一個循環(huán)中進(jìn)行添加后的第二個循環(huán)的結(jié)果。
<h2>Before</h2> <div id="loopResultsBefore"></div> <h2>After</h2> <div id="loopResultsAfter"></div>
const beforeDiv = document.getElementById('loopResultsBefore'); const afterDiv = document.getElementById('loopResultsAfter'); const obj = { "a": "JavaScript", 1: "PHP", "b": "Python", 2: "Java" }; for (let key in obj) { beforeDiv.innerHTML += key + ": " + obj[key] + "<br />"; if (!isNaN(key)) { obj[key - 1] = obj[key]; } } for (let key in obj) { afterDiv.innerHTML += key + ": " + obj[key] + "<br />"; } // Before // 1: PHP // 2: Java // a: JavaScript // b: Python // After // 0: PHP // 1: Java // 2: Java // a: JavaScript // b: Python
正如你在上面的例子中看到的,被添加的元素并沒有被迭代。
for循環(huán)的替代方案
forEach
在JavaScript中是數(shù)組原型的一個方法,它允許我們在回調(diào)函數(shù)中遍歷數(shù)組的元素和它們的索引。
回調(diào)函數(shù)是你傳遞給另一個方法或函數(shù)的函數(shù),作為該方法或函數(shù)執(zhí)行的一部分而被執(zhí)行。當(dāng)涉及到JavaScript中的forEach
時,它意味著回調(diào)函數(shù)將在每個迭代中執(zhí)行,接收迭代中的當(dāng)前項作為參數(shù)。
舉例來說,下面的語句使用forEach
迭代arr
變量,并在console
中打印value
:
arr.forEach((value) => console.log(value));
你也可以訪問數(shù)組的索引:
arr.forEach((value, index) => console.log(value, index));
JavaScript forEach
循環(huán)也可以使用Object.keys()
來迭代對象,把你想迭代的對象傳給它,它返回對象的自有屬性數(shù)組:
Object.keys(obj).forEach((key) => console.log(obj[key]));
另外,如果你不需要使用Object.values()
來訪問屬性,你可以用forEach
來直接循環(huán)屬性的值:
Object.values(obj).forEach((value) => console.log(value));
注意,Object.values()
返回項的順序與for...in
相同。
總結(jié)
通過使用JavaScript for...in
循環(huán),我們可以循環(huán)對象的鍵或?qū)傩?。在迭代對象屬性或進(jìn)行調(diào)試時,它可能很有用,但在迭代數(shù)組或?qū)ο筮M(jìn)行修改時,應(yīng)該避免使用for...in
循環(huán)。
到此這篇關(guān)于如何在JavaScript中使用for循環(huán)的文章就介紹到這了,更多相關(guān)js使用for循環(huán)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JavaScript 語言基礎(chǔ)知識點總結(jié)(思維導(dǎo)圖)
這篇文章通過思維導(dǎo)圖格式總結(jié)了JavaScript 語言基礎(chǔ)知識點,想要學(xué)習(xí)js的朋友可以參考下2013-11-11js實現(xiàn)rem自動匹配計算font-size的示例
本篇文章主要介紹了js實現(xiàn)rem自動匹配計算font-size的示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-11-11javascript 實現(xiàn)字符串反轉(zhuǎn)的三種方法
這篇文章主要介紹了javascript 實現(xiàn)字符串反轉(zhuǎn)的三種方法,有需要的朋友可以參考一下2013-11-11JavaScript實現(xiàn)函數(shù)緩存及應(yīng)用場景
在JavaScript中,可以通過函數(shù)緩存來提高函數(shù)的執(zhí)行效率,本文就來介紹一下JavaScript實現(xiàn)函數(shù)緩存及應(yīng)用場景,具有一定的參考價值,感興趣的可以了解一下2024-01-01設(shè)為首頁加入收藏兼容360/火狐/谷歌/IE等主流瀏覽器的代碼
不用找了我試過好多次ie、火狐、谷歌瀏覽器此代碼都是不可逆兼容,想把這個問題完全解決,方法就是像其他主流網(wǎng)站一樣,下面是我的簡單解決方案2013-03-03JavaScript 如何刪除小數(shù)點后的數(shù)字
這篇文章主要介紹了JavaScript 刪除小數(shù)點后的數(shù)字實例代碼,代碼簡單易懂,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-07-07