辨析js遍历对象与数组的方法
1 遍历对象的方法?
(1) for…in(也可遍历数组,但效率较低,一般用来遍历对象)
示例:
// 生成一个原型上有属性并且有可枚举属性与不可枚举属性的对象
const data = Object.create({
name: "这是原型上的属性", //生成原型上的属性
});
data.age = 23; // 对象自身(可枚举)属性
Object.defineProperty(data, "sex", {
// 对象自身的不可枚举属性
value: "女",
Enumerable: false, //不可枚举
});
// 使用for...in遍历data
for (let key in data) {
console.log(key); // 获得data自身可枚举属性及原型上的属性
// 结果: age、name
}
(2) Object.keys()
示例:
// 生成一个原型上有属性并且有可枚举属性与不可枚举属性的对象
const data = Object.create({
name: "这是原型上的属性", //生成原型上的属性
});
data.age = 23; // 对象自身(可枚举)属性
Object.defineProperty(data, "sex", {
// 对象自身的不可枚举属性
value: "女",
Enumerable: false, //不可枚举
});
// 使用Object.kes遍历data
Object.keys(data).forEach(key=>{
console.log(key) // 获得data自身可枚举属性
// 结果: age
})
(3) Object.getOwnPropertyNames()
示例:
// 生成一个原型上有属性并且有可枚举属性与不可枚举属性的对象
const data = Object.create({ name: "这是原型上的属性", //生成原型上的属性 }); data.age = 23; // 对象自身(可枚举)属性 Object.defineProperty(data, "sex", { // 对象自身的不可枚举属性 value: "女", Enumerable: false, //不可枚举 }); console.log(data); // 使用Object.getOwnPropertyNames()遍历data Object.getOwnPropertyNames(data).forEach(key=>{ console.log(key) // 获得data自身可枚举属性及不可枚举属性 // 结果: age、sex })
总结:
for…in获取对象自身的可枚举属性及原型上的属性(可通过hasOwnProperty()过滤原型上的属性);
Object.keys只获取对象自身的可枚举属性;
Object.getOwnPropertyNames获取对象自身的可枚举及不可枚举属性。
2 遍历数组的方法?
(1) for循环
示例:
const data = [
{ id: 1, name: "张三" },
{ id: 2, name: "李四" },
{ id: 3, name: "王五" },
];
// for循环
for (let i = 0; i < data.length; i++) {
console.log(data[i]);
}
// 优化效率的for循环(将length进行缓存)
for (let i = 0, length = data.length; i < length; i++) {
console.log(data[i]);
}
(2) forEach
示例:
// 数组的遍历
const data = [
{ id: 1, name: "张三" },
{ id: 2, name: "李四" },
{ id: 3, name: "王五" },
];
// forEach遍历
data.forEach(ee=>{
console.log(ee)
})
(3) while遍历
示例:
// 数组的遍历
const data = [
{ id: 1, name: "张三" },
{ id: 2, name: "李四" },
{ id: 3, name: "王五" },
];
// while遍历
let i=0;
while(i<data.length){
console.log(data[i]);
i++
}
(4) map
示例:
// 数组的遍历
const data = [
{ id: 1, name: "张三" },
{ id: 2, name: "李四" },
{ id: 3, name: "王五" },
];
// map遍历
data.map(ee=>{
console.log(ee)
})
(5) for…of
示例:
// 数组的遍历
const data = [
{ id: 1, name: "张三" },
{ id: 2, name: "李四" },
{ id: 3, name: "王五" },
];
// for...of遍历
for(let i of data){
console.log(i)
}
总结:
for写法麻烦,每一步需要手动处理;
foreach遍历数组的每一项,不影响原数组,性能差,不能中断循环,也不能return;
map支持return,返回值相当于克隆了一份数据,可改变克隆的部分但不影响原数组;
for…of语法简洁,可以与 break、continue 和 return 配合使用。
辨析js遍历对象与数组的方法的更多相关文章
- js遍历对象的属性和方法
js遍历对象的属性和方法 一.总结 二.实例 练习1:具有默认值的构造函数 实例描述: 有时候在创建对象时候,我们希望某些属性具有默认值 案例思路: 在构造函数中判断参数值是否为undefined,如 ...
- JS遍历对象和数组总结
在日常工作过程中,我们对于javaScript遍历对象.数组的操作是十分的频繁的,今天把经常用到的方法总结一下! 一.遍历对象 1.使用Object.keys()遍历 返回一个数组,包括对象自身的(不 ...
- JS遍历对象或者数组
一.纯js实现 <script> var obj = {"player_id":"GS001","event_id":" ...
- JS遍历对象的几种方法
几天前一个小伙伴问我 Object.getOwnPropertyNames() 是干什么用的 平时还真没有使用到这个方法,一时不知如何回答 从方法名称来分析,应该是返回的是对象自身属性名组成的数组 那 ...
- js遍历对象的数组
遍历数组: 1.js关键for遍历 2.jquery提供each功能 ----------------------------------- $.each(array, function(){ ...
- js声明 对象,数组 的方法
i={} 对象字面量 等同 i = new Object();i=[] 数组字面量 等同 i = new Array();
- JS合并两个数组的方法
JS合并两个数组的方法 我们在项目过程中,有时候会遇到需要将两个数组合并成为一个的情况.比如: var a = [1,2,3]; var b = [4,5,6]; 有两个数组a.b,需求是将两个数组合 ...
- jquery中each遍历对象和数组示例
通用遍历方法,可用于遍历对象和数组.$().each(),回调函数拥有两个参数: 第一个为对象的成员或数组的索引,第二个为对应变量或内容.如需退出each循环可使回调函数返回false 现有如下两个s ...
- javaScript遍历对象、数组总结(转载)
javaScript遍历对象.数组总结 转载来源 https://www.cnblogs.com/chenyablog/p/6477866.html 在日常工作过程中,我们对于javaScript遍 ...
随机推荐
- 西南民族大学第十二届程序设计竞赛(同步赛) A.逃出机房 (bfs)
题意:有来两个人A和B,A追B,A和B每次向上下左右移动一个单位,一共有两扇门,问A是否可以追上B(在门口追上也算合法). 题解:当时看题意说在门口也算?就觉得是判断两个人到门口的时间,对他们两个人分 ...
- 单源最短路问题 Dijkstra 算法(朴素+堆)
选择某一个点开始,每次去找这个点的最短边,然后再从这个开始不断迭代,更新距离. 代码: 朴素(vector存图) #include <iostream> #include <cstd ...
- kubernetes实战-交付dubbo服务到k8s集群(六)使用blue ocean流水线构建dubbo-consumer服务
我们这里的dubbo-consumer是dubbo-demo-service的消费者: 我们之前已经在jenkins配置好了流水线,只需要填写参数就行了. 由于dubbo-consumer用的gite ...
- python3 anaconda 安装pyhook3 pythoncom(pywin32)
为什么不安装pyhook 1.pyhook不支持python3 2.网络上有一些方法下载pyhook的whl然后pip安装到python3,可以运行,但是会因为编码问题导致移动到窗口标题含有非ASCI ...
- Leetcode(885)- 救生艇
第 i 个人的体重为 people[i],每艘船可以承载的最大重量为 limit. 每艘船最多可同时载两人,但条件是这些人的重量之和最多为 limit. 返回载到每一个人所需的最小船数.(保证每个人都 ...
- 机器学习(四):通俗理解支持向量机SVM及代码实践
上一篇文章我们介绍了使用逻辑回归来处理分类问题,本文我们讲一个更强大的分类模型.本文依旧侧重代码实践,你会发现我们解决问题的手段越来越丰富,问题处理起来越来越简单. 支持向量机(Support Vec ...
- CSS & new class name
CSS & new class name { test: /\.((s*)css|sass)$/, // test: /\.(css|scss|sass)$/, use: ExtractTex ...
- 钓鱼教程 All In One
钓鱼教程 All In One youtube https://www.youtube.com/results?search_query=钓鱼教程&sp=CAM%3D 钓鱼证 https:// ...
- leetcode best solutions
leetcode best solutions how to learning algorithms form the leetcode best solutions https://leetcode ...
- useful life skills website
useful life skills website 绳子打结技巧 https://www.animatedknots.com/complete-knot-list tools https://tab ...