JavaScript 數(shù)組遍歷的五種方法
在使用 JavaScript 編寫代碼過程中,可以使用多個方法對數(shù)組進行遍歷;包括 for循環(huán)、forEach循環(huán)、map 循環(huán)、forIn循環(huán)和forOf循環(huán)等方法。
一、for 循環(huán):基礎(chǔ)、簡單
這是最基礎(chǔ)和常用的遍歷數(shù)組的方法;各種開發(fā)語言一般都支持這種方法。
let arr = ['a','b','c','d','e'];
for (let i = 0, len = arr.length; i < len; i++) {
console.log(i); // 0 1 2 3 4
console.log(arr[i]); //a b c d e
}
二、forEach() 方法:使用回調(diào)函數(shù)
forEach() 這是數(shù)組對象的一個方法;其接受一個回調(diào)函數(shù)為參數(shù)。
回調(diào)函數(shù)中有三個參數(shù):
- 1st:數(shù)組元素(必選)
- 2nd:數(shù)組元素索引值(可選)
- 3rd:數(shù)組本身(可選)
let arr = ['a','b','c','d','e'];
arr.forEach((item,index,arr)=> {
console.log(item); // a b c d e
console.log(index); // 0 1 2 3 4
console.log(arr); // ['a','b','c','d','e']
})
三、map() 方法:使用回調(diào)函數(shù)
其使用方式和 forEach() 方法相同。
var arr = [
{name:'a',age:'18'},
{name:'b',age:'19'},
{name:'c',age:'20'}
];
arr.map(function(item,index) {
if(item.name == 'b') {
console.log(index) // 1
}
})
四、for..in 循環(huán):遍歷對象和數(shù)組
for…in循環(huán)可用于循環(huán)對象和數(shù)組。
推薦用于循環(huán)對象,也可以用來遍歷json。
let obj = {
name: '王大錘',
age: '18',
weight: '70kg'
}
for(var key in obj) {
console.log(key); // name age weight
console.log(obj[key]); // 王大錘 18 70kg
}
----------------------------
let arr = ['a','b','c','d','e'];
for(var key in arr) {
console.log(key); // 0 1 2 3 4 返回數(shù)組索引
console.log(arr[key]) // a b c d e
}
五、for…of 循環(huán):遍歷對象和數(shù)組
可循環(huán)數(shù)組和對象,推薦用于遍歷數(shù)組。
for…of提供了三個新方法:
- key()是對鍵名的遍歷;
- value()是對鍵值的遍歷;
- entries()是對鍵值對的遍歷;
let arr = ['科大訊飛', '政法BG', '前端開發(fā)'];
for (let item of arr) {
console.log(item); // 科大訊飛 政法BG 前端開發(fā)
}
// 輸出數(shù)組索引
for (let item of arr.keys()) {
console.log(item); // 0 1 2
}
// 輸出內(nèi)容和索引
for (let [item, val] of arr.entries()) {
console.log(item + ':' + val); // 0:科大訊飛 1:政法BG 2:前端開發(fā)
}
六、補充
6.1、break 和 Continue 問題
在 forEach、map、filter、reduce、every、some 函數(shù)中 break 和 continue 關(guān)鍵詞都會不生效,因為是在function中,但function解決了閉包陷阱的問題。
要想使用 break、continue 可以使用 for、for...in、for...of、while。
6.2、數(shù)組和對象
用于遍歷數(shù)組元素使用:for(),forEach(),map(),for...of 。
用于循環(huán)對象屬性使用:for...in。
以上就是JavaScript 數(shù)組遍歷的五種方法的詳細內(nèi)容,更多關(guān)于JavaScript 數(shù)組遍歷的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
實現(xiàn)非常簡單的js雙向數(shù)據(jù)綁定
Angular實現(xiàn)了雙向綁定機制。所謂的雙向綁定,無非是從界面的操作能實時反映到數(shù)據(jù),數(shù)據(jù)的變更能實時展現(xiàn)到界面。本文給大家詳細介紹js雙向數(shù)據(jù)綁定,感興趣的朋友參考下2015-11-11
JavaScript數(shù)組隨機排列實現(xiàn)隨機洗牌功能
這篇文章主要介紹了JavaScript數(shù)組隨機排列實現(xiàn)隨機洗牌功能的方法,涉及javascript中基于list.sort方法實現(xiàn)數(shù)組隨機排列的技巧,可應(yīng)用于隨機洗牌,非常具有實用價值,需要的朋友可以參考下2015-03-03
javascript簡寫常用的12個技巧(可以大大減少你的js代碼量)
這篇文章主要跟大家分享了javascript簡寫常用的12個技巧,通過這12個技巧可以大大減少你的js代碼量,看懂一種是入門,全懂就是大神,你能知道幾個呢?需要的朋友們下面跟著小編來一起學(xué)習(xí)學(xué)習(xí)下吧。2017-08-08

