JavaScript中,數組和對象的遍歷方法總結

来源:https://www.cnblogs.com/52binbin/archive/2020/02/23/12355063.html
-Advertisement-
Play Games

迴圈遍歷是寫程式很頻繁的操作,JavaScript 提供了很多方法來實現。 這篇文章將分別總結數組和對象的遍歷方法,新手可以通過本文串聯起學過的知識。 數組遍歷 方法一:for 迴圈 for 迴圈是使用最多,也是性能優化最好的一種遍歷方式。 ` 方法 方法 方法是 ES5 新增,專為下麵這種累加操作 ...


迴圈遍歷是寫程式很頻繁的操作,JavaScript 提供了很多方法來實現。

這篇文章將分別總結數組和對象的遍歷方法,新手可以通過本文串聯起學過的知識。

數組遍歷

方法一:for 迴圈

for 迴圈是使用最多,也是性能優化最好的一種遍歷方式。

var arr = ["a", "b", "c"];
for (var i = 0; i < arr.length; i++) {
  console.log(arr[i])
}
// a b c

同樣常規的迴圈類型還有 while 迴圈和 do/while 迴圈。

它們之間的區別在於,for 迴圈預先知道迴圈次數,while 迴圈不知道迴圈次數,do/while 至少會迴圈次數。

方法二:for-of 遍歷

for-of 是 ES6 新增的語法。它直接遍歷值,而不是數組下標(或對象屬性)。

var arr = ["a", "b", "c"];
for (let item of arr) {
  console.log(item);
}
// a b c

實際上,for-of 語句不僅可以迴圈遍曆數組對象。

還可以迭代 Array、Map、Set、String 等對象。

// 遍歷String
let str = "Hello";
for (let value of str) {
  console.log(value)
}
// H e l l o

// 遍歷Map
let iterable = new Map([["a", 1], ["b", 2], ["c", 3]]);
for (let entry of iterable) {
  console.log(entry);
}
// ["a", 1]
// ["b", 2]
// ["c", 3]
for (let [key, value] of iterable) {
  console.log(value);
}
// 1
// 2
// 3

for-of 的工作原理是,向迴圈對象請求一個迭代器對象,然後通過迭代器對象的next()方法來獲得返回值。

數組內置了 @@iterator@@iterator不是迭代器,而是返回一個迭代器對象的函數。

var arr = ["a", "b","c"];
var it = arr[Symbol.iterator]();
console.log(it.next());  // { value: 'a', done: false }
console.log(it.next());  // { value: 'b', done: false }
console.log(it.next());  // { value: 'c', done: false }
console.log(it.next());  // { value: undefined, done: true }

上面代碼中,value 表示當前遍歷值,done 是布爾值,表示是否還有可以遍歷的值。

需要註意的是,普通對象沒有內置@@iterator,所以無法使用 for-of 遍歷。

這麼做的原因很複雜,簡單來說,就是為了避免影響未來的對象類型。

不過,我們可以通過Object.defineProperty(...)給對象定義@@iterator

詳細可以通過這裡瞭解

方法三:數組方法

為了適應不同方式的遍歷,JavaScript 內置了許多的數組方法。

例如比較常用的forEach()方法,寫起來,可以讓代碼更簡潔。

var arr = ["a", "b", "c"];
arr.forEach((index, item) => {
  console.log(index, item)
})
// a 0
// b 1
// c 2

map()方法

var arr = [1, 2, 3];
var newArr = arr.map(item => {
  return item * 2;
});
console.log(newArr);  // [2, 4, 6]

filter()方法

var arr = [1, 2, 3];
var newArr = arr.filter(item => {
  return item > 1;
});
console.log(newArr); // [2, 3]

reduce()方法是 ES5 新增,專為下麵這種累加操作的設計的。

實際能做的事情遠比這要豐富,本文只是簡單介紹基本用法,詳細可以查看本文

var arr = [1, 2, 3];
var sum = arr.reduce((pre, cur) => {
  return pre + cur;
});
console.log(sum); // 6

every()方法用於檢測數組元素是否全部符合指定條件。

它通常和下麵的some()方法放在一起理解。

var arr = [1, 2, 3];
var bool = arr.every(item => {
  return item < 5;
});
console.log(bool); // true

some()方法用於檢測數組是否存在一個符合指定條件的元素。

下麵的例子是檢測數組元素是否存在 Number 類型。

var arr = ["a", 1, "b"];
var bool = arr.some(item => {
  return typeof item === "number";
});
console.log(bool);  // true

對象的遍歷方法

對象的遍歷相對麻煩一些。

有兩種方式可以實現對象的遍歷,一種是直接使用 for-in 迴圈;另一方式,是將對象轉換成數組,再進行遍歷。

方法一:for-in 迴圈

for-in 專門用於遍歷對象的可枚舉屬性,包括 prototype 原型鏈上的屬性,因此性能會比較差。

什麼是可枚舉屬性

從名字上可以看出,就是該屬性會出現在對象的迭代(枚舉)中,比如 for-in 迴圈中。

var obj = { a: 2, b: 4, c: 6 };
for (let key in obj) {
  console.log(key);
}
// a b c

方法二:Object.keys() 和 Object.getOwnPropertyNames()

Object.key()會返回一個數組,包含所有可枚舉屬性;Object.getOwnPropertyNames()也會返回一個數組,包含所有元素,不管是否可枚舉。

需要說明的是,兩者都只查找對象的自定義屬性。

var obj = { a: 2, b: 4, c: 6 };
// Object.keys()
Object.keys(obj).forEach(key => {
  console.log(key);
})
// a b c

// Object.getOwnPrepertyNames()
Object.getOwnPropertyNames(obj).forEach(key => {
  console.log(key);
})
// a b c

此外,還可以通過Reflect.ownKeys(obj)方法來遍歷。

它返回一個數組,包含對象自定義的屬性,不管屬性名是 Symbol 還是字元串,也不管是否可枚舉。

由於使用不多,這裡瞭解一下即可。

最後,整理了不同對象遍歷方法的特點。

方式 查找原型鏈屬性 查找自定義屬性 查找不可枚舉屬性
for-in
Object.keys(..)
Object.getOwnpropertyNames(..)

吾兒濱濱


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 達夢資料庫 RAC DMDSC部署的關鍵點 環境準備 網路準備(ip地址分配)、共用磁碟準備和掛載 ifconfig enp0s8 10.1.2.101;ifconfig enp0s9 192.168.56.101 ifconfig enp0s8 10.1.2.102;ifconfig enp0s9 ...
  • 1、MySQL邏輯架構 日常在CURD的過程中,都避免不了跟資料庫打交道,大多數業務都離不開資料庫表的設計和SQL的編寫,那如何讓你編寫的SQL語句性能更優呢? 先來整體看下MySQL邏輯架構圖: MySQL整體邏輯架構圖可以分為Server和存儲引擎層。 Server層: Server層涵蓋了My ...
  • 本文內容是採集的好幾位博主的博文進行的一個整合,內容更為精準和詳盡,以下是我參照的幾篇博文地址: 微軟官方文檔:https://docs.microsoft.com/zh-cn/sql/linux/sql-server-linux-setup?view=sql-server-ver15 Callou ...
  • MySQL基礎(4) | 視圖 基本語法 1.創建 語法說明如下。 ``:指定視圖的名稱。該名稱在資料庫中必須是唯一的,不能與其他表或視圖同名。 ``:指定創建視圖的 SELECT 語句,可用於查詢多個基礎表或源視圖。 對於創建視圖中的 SELECT 語句的指定存在以下限制: 用戶除了擁有 CREA ...
  • 一.什麼是MongoDB? MongoDB is a document database with the scalability and flexibility that you want with the querying and indexing that you need (MongoDB是 ...
  • Re:一些百科上的黑幕實現 這裡的黑幕不是那個黑幕啦!你去看看萌娘百科就知道了! 不動它,它就是個黑條子。你盯著它看什麼都不會發生。 當你把滑鼠移到了黑幕上,一些神奇的事情就會發生…… 反正我覺得這很好看(♥∀♥) 不知道你們喜不喜歡呀(≧∇≦)ノ ...
  • 一、 製作一個相片牆 二、 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <style> *{ margin:0; padding:0; } ul{ height: 400px; ...
  • 正則驗證合法_有效的IP地址(ipv4/ipv6) 不墨跡直接上代碼: 正則表達式: /^((2[0-4]\d|25[0-5]|[01]?\d\d?)\.){3}(2[0-4]\d|25[0-5]|[01]?\d\d?)$/ JS函數方法: var util = { isValidIp: funct ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...