JavaScript中,数组和对象的遍历方法总结
循环遍历是写程序很频繁的操作,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
。
详细可以通过[这里了解](https://github.com/getify/You-Dont-Know-JS/blob/1ed-zh-CN/this %26 object prototypes/ch3.md)。
方法三:数组方法
为了适应不同方式的遍历,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(..) |
❌ | ✅ | ✅ |
吾儿滨滨
JavaScript中,数组和对象的遍历方法总结的更多相关文章
- JS中数组与对象的遍历方法实例小结
一.数组的遍历: 首先定义一个数组 1 arr=['snow','bran','king','nightking']; 1.for循环,需要知道数组的长度; 2.foreach,没有返回值,可以不知道 ...
- JavaScript 中的12种循环遍历方法
原文:JavaScript 中的12种循环遍历方法 题目:请介绍 JavaScript 中有哪些循环和遍历的方法,说说它们的应用场景和优缺点? 1.for 循环 let arr = [1,2,3];f ...
- JavaScript中数组去重的几种方法
JavaScript中数组去重的几种方法 正常情况下,数据去重的工作一般都是由后端同事来完成的,但是前端也要掌握好处理数据的能力,万一去重的工作交给我们大前端处理,我们也不能怂呀.现在我总结了一些去重 ...
- JS数组与对象的遍历方法大全
本文简单解析各种数组和对象属性的遍历方法: 原生for循环.for-in及forEach ES6 for-of方法遍历类数组集合 Object.key()返回键名的集合 jQuery的$.each() ...
- JavaScript:JavaScript中常见获取对象元素的方法
介绍: javascript中常见的3种获取元素的方法,分别是通过元素ID.通过标签名字和通过类名字来获取 操作如下: 1.getElementById DOM提供了一个名为getElementByI ...
- JavaScript中数组类型的属性和方法
除了Object,Array类型应该是ECMAScript中最常用的类型了. ECMAScript的数组虽然也是数据的有序列表,但还是与其他语言中的数组有很大的区别.比如ECMAScript数组每一项 ...
- javascript中的12种循环遍历方法1
1:for循环 let arr = [1,2,3]; for(let i =0;i<arr.length;i++){ console.log(i,arr[i]) } //for循环是js中最常用 ...
- JavaScript中数组元素删除的七大方法汇总
原文链接:https://blog.csdn.net/u010323023/article/details/52700770 在JavaScript中,除了Object之外,Array类型恐怕就是最常 ...
- javascript中的12种循环遍历方法
1.for (自定义条件) 循环 let arr = [1,2,3]; for(let i =0;i<arr.length;i++){ console.log(i,arr[i]) } 2.for ...
随机推荐
- 切蛋糕(贪心 or 优先队列)
链接:https://www.nowcoder.com/acm/contest/80/D来源:牛客网 最可爱的applese生日啦,他准备了许多个质量不同的蛋糕,想请一些同学来参加他的派对为他庆生,为 ...
- AD19覆铜与边框间距设置方法
转载请注明出处,并附带本文网址https://www.cnblogs.com/brianblog/p/9894867.html, 由于高版本AD不能将机械层直接转变为KEPP OUT LAYER层,所 ...
- java 三元运算
一.格式: 数据类型 变量名称 = 条件判断 ? 表达式a : 表达式b; 二.注意: 1.不是打印操作时,需要 三元运算的右则 2.表达式a和表达式b的值,必须要和变量名称 的数据类型相等 貌似和C ...
- Java框架之MyBatis 06-全局配置-mapper映射-分步查询
MyBatis MyBatis是Apache的一个开源项目iBatis, iBatis一词来源于“internet”和“abatis”的组合,是一个基于Java的持久层框架. iBatis 提供的持 ...
- [bzoj2668] [洛谷P3159] [cqoi2012] 交换棋子
Description 有一个n行m列的黑白棋盘,你每次可以交换两个相邻格子(相邻是指有公共边或公共顶点)中的棋子,最终达到目标状态.要求第i行第j列的格子只能参与mi,j次交换. Input 第一行 ...
- HTML超全笔记
HTML概述 概念:是最基础的网页开发语言 Hyper Text Markup Language 超文本标记语言 超文本: 超文本是用超链接的方法,将各种不同空间的文字信息组织在一起的网状文本. 标记 ...
- CAS的ABA问题详解
CAS的ABA问题详解 ABA问题 在多线程场景下CAS会出现ABA问题,关于ABA问题这里简单科普下,例如有2个线程同时对同一个值(初始值为A)进行CAS操作,这三个线程如下 1.线程1,期望值为A ...
- nginx之文件配置
nginx配置规则 nginx由受配置文件中指定的指令控制的模块组成 伪指令分为简单伪指令和块伪指令 简单的指令由名称和参数组成,这些名称和参数之间用空格分隔,并以分号(;)结尾 块指令的结构 与 简 ...
- python 学习笔记2 匿名函数
# 匿名函数 lambda a,b : a+b# a.j.from functools import reduce students = [{'name': '张三', 'age': 18, 'hei ...
- 请注意安全!你的mongodb已经被黑了!互联网安全生产大过天!
你所不知道的入侵,你的服务器安全吗?你的数据库安全吗? 讲真,也许是我以前一直从事内网应用开发吧,我从来没有想过在互联网上,有那么多扫描器. 10月份的时候,受人委托我做了一个简单的抢单插件,里面有用 ...