JavaScript 中 Object,Map,Set 及數組遍歷方法

来源:https://www.cnblogs.com/touryung/archive/2023/02/23/17149579.html
-Advertisement-
Play Games

Object(對象) for in 遍歷出對象可枚舉的"屬性",包含繼承的可枚舉屬性 var person = { name: '小明', birth: 1990, height: 1.70 }; for(var x in person){ console.log(x); console.log(p ...


Object(對象)

for in

  • 遍歷出對象可枚舉的"屬性",包含繼承的可枚舉屬性
var person = {
  name: '小明',
  birth: 1990,
  height: 1.70
};
for(var x in person){
  console.log(x);
  console.log(person[x]); // 不能用person.x,會被認為是取person的x屬性
}

Object.keys,Object.values

  • 分別遍歷出對象的"屬性"和"值",不包含繼承的
var person = {
  id:1,
  name:'zhangsan',
  age:18
}

console.log(Object.keys(person));
console.log(Object.values(person)); // 輸出數組
Object.keys(person).forEach((key)=>{
  console.log(key+':'+person[key]);
})

Object.getOwnPropertyNames

  • 遍歷出對象的"屬性",不包含繼承的
  • Object.keys 的區別: Object.keys 返回可枚舉的,Object.getOwnPropertyNames 返回所有的。
const person = {
  id:1,
  name:'zhangsan',
  age:18
}
Object.getOwnPropertyNames(person).forEach(function(key){
  console.log(key+':'+person[key]);
})

Map(哈希表)

for of

  • 遍歷出每個鍵值對數組
var m = new Map([[1, 'x'], [2, 'y'], [3, 'z']]);
for (var x of m) {
  console.log(x[0] + '=' + x[1]);
}

map.values,map.keys

  • Object

forEach

var m = new Map([[1, 'x'], [2, 'y'], [3, 'z']]);
m.forEach((value, key, map)=>{
  console.log(value);
})

map.entries

  • 作用同 for of

Set(集合)

同 Map,區別是:

  • set.keysset.values 相等
  • forEach 中前兩個參數一致,都是元素本身
  • set.entries 會遍歷出數組,類似 ['A', 'A'],不建議使用

Array(數組)

  • 普通 for 遍歷
  • for 改良:for(var i=0, len=arr.length, i<len, i++)
  • for in (效率低)
  • for of
  • forEach

具體情況不贅述

最後

for in 和 for of 區別

for in 迴圈遍歷的是對象的屬性名稱

Array 數組實際上也是一個對象,它的每個元素的索引被視為一個屬性,當我們給 Array 對象添加了額外的屬性後,for in 迴圈將出現瑕疵:

var a = ['A', 'B', 'C'];
a.name = 'Hello';
for (var x in a) {
  console.log(x); // '0', '1', '2', 'name'
}

for in 迴圈將把 name 包括在內,但 Arraylength 屬性卻不包括在內

for of 迴圈集合屬性對應的值

var a = ['A', 'B', 'C'];
a.name = 'Hello';
for (var x of a) {
  console.log(x); // 'A', 'B', 'C'
}

Object 不能用 for of 遍歷,MapSet 不能用 for in 遍歷

forEach 遍歷類型

forEach 適用於遍曆數組,MapSet。其他類型比如 Object 可以用 Object.keys 得到數組然後遍歷


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

-Advertisement-
Play Games
更多相關文章
  • 摘要:本文就使用springboot結合mybatis plus在項目中實現對GaussDB(DWS)的增刪改查操作。 本文分享自華為雲社區《基於SpringBoot實現操作GaussDB(DWS)的項目實戰【玩轉PB級數倉GaussDB(DWS)】》,作者:清雨小竹。 GaussDB(DWS) 數 ...
  • PS:本教程破解工具均收集於網路,請勿商用,僅供個人學習使用,如有侵權,請聯繫作者刪除。若條件允許,希望大家購買正版 ! 話不多說,直接上乾貨教程!!! 第一步:Get Navicat premium 15安裝包和激活工具 Navicat Premium 15 永久激活工具(親測可用) 第二步:開始 ...
  • EE模塊是搜索系統中改善生態、探索商品的重要鏈路,其目標是緩解數據馬太效應導致模型對商品排序豐富性、探索性不足,帶來的系統非最優解問題。以下分別從模型迭代、線上實驗指標、離線評估體系介紹相應模塊的優化。 ...
  • PostgreSQL 作為當下流行的資料庫,不少開發者因其開源、可靠、可擴展等特性把它應用到實際的生產環境中,幫助無數 PostgreSQL 廠商的 Percona 編製了一個最常見錯誤的列表。即使你認為自己已經正確地安裝配置 PostgreSQL,或許仍會發現此列表對於驗證你的安裝配置大有裨益。 ... ...
  • 前言: 最近接到個需求,我們新產品上的外包側APP需要使用硬體唯一ID(不管怎麼升級怎麼操作,ID始終不變和硬體綁定),用來做許可權校驗。 由於瞭解到安卓ID或序列號都會在擦除升級後重新隨機生成,所以這裡使用硬體上的ID來作為唯一ID,接下來進入正題 此篇以安卓7.1系統為例 一,常用硬體信息ID 這 ...
  • 一、 獲取Push Token的方式 獲取Push Token有兩種方式:一種是調用getToken方法向Push服務端請求Token,當getToken方法返回為空時,Token可通過onNewToken方法返回,因此需要實現onNewToken方法;另一種是自動初始化,Token通過onNewT ...
  • 官方文檔https://nativesupport.dcloud.net.cn/AppDocs/usesdk/android.html一、將寫好的uniapp右鍵→發行→原生app-本地打包→生成本地打包App資源(它會要求你登錄賬號)二、它會生成一個文件夾三、點擊連接可以直接進入文件夾,路徑往上一 ...
  • 全局組件 微信小程式組件關係中,父組件使用子組件需要在父組件index.json中引入子組件,然後在父組件頁面中使用,這種組件的對應狀態是一對一的,一個組件對應一個頁面。如果有一個全局彈窗(登錄),那麼每個頁面引入一次組件會非常麻煩,這裡就需要封裝全局彈窗,在頁面直接引入使用即可。 微信小程式提供全 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...