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语法简洁,可以与 breakcontinue 和 return 配合使用。

辨析js遍历对象与数组的方法的更多相关文章

  1. js遍历对象的属性和方法

    js遍历对象的属性和方法 一.总结 二.实例 练习1:具有默认值的构造函数 实例描述: 有时候在创建对象时候,我们希望某些属性具有默认值 案例思路: 在构造函数中判断参数值是否为undefined,如 ...

  2. JS遍历对象和数组总结

    在日常工作过程中,我们对于javaScript遍历对象.数组的操作是十分的频繁的,今天把经常用到的方法总结一下! 一.遍历对象 1.使用Object.keys()遍历 返回一个数组,包括对象自身的(不 ...

  3. JS遍历对象或者数组

    一.纯js实现 <script> var obj = {"player_id":"GS001","event_id":" ...

  4. JS遍历对象的几种方法

    几天前一个小伙伴问我 Object.getOwnPropertyNames() 是干什么用的 平时还真没有使用到这个方法,一时不知如何回答 从方法名称来分析,应该是返回的是对象自身属性名组成的数组 那 ...

  5. js遍历对象的数组

    遍历数组: 1.js关键for遍历 2.jquery提供each功能 ----------------------------------- $.each(array, function(){     ...

  6. js声明 对象,数组 的方法

    i={} 对象字面量 等同 i = new Object();i=[] 数组字面量 等同 i = new Array();

  7. JS合并两个数组的方法

    JS合并两个数组的方法 我们在项目过程中,有时候会遇到需要将两个数组合并成为一个的情况.比如: var a = [1,2,3]; var b = [4,5,6]; 有两个数组a.b,需求是将两个数组合 ...

  8. jquery中each遍历对象和数组示例

    通用遍历方法,可用于遍历对象和数组.$().each(),回调函数拥有两个参数: 第一个为对象的成员或数组的索引,第二个为对应变量或内容.如需退出each循环可使回调函数返回false 现有如下两个s ...

  9. javaScript遍历对象、数组总结(转载)

    javaScript遍历对象.数组总结  转载来源 https://www.cnblogs.com/chenyablog/p/6477866.html 在日常工作过程中,我们对于javaScript遍 ...

随机推荐

  1. fzu2204 7

    Problem Description n个有标号的球围成一个圈.每个球有两种颜色可以选择黑或白染色.问有多少种方案使得没有出现连续白球7个或连续黑球7个.  Input 第一行有多组数据.第一行T表 ...

  2. Redundant Paths POJ - 3177 把原图变成边—双连通图

    无向图概念:(这里的x->y表示x和y之间有一条无向边)1.桥:对于一个无向图,如果删除某条边后,该图的连通分量增加,则称这条边为桥 比如1->2->3->4这样一个简单得图一 ...

  3. Codeforces Round #527 (Div. 3) C. Prefixes and Suffixes (思维,字符串)

    题意:给你某个字符串的\(n-1\)个前缀和\(n-1\)个后缀,保证每个所给的前缀后缀长度从\([1,n-1]\)都有,问你所给的子串是前缀还是后缀. 题解:这题最关键的是那两个长度为\(n-1\) ...

  4. GDKOI2021 爆炸记

    @ 目录 GDKOI2021 爆炸记 前言 普及(Day 1~3) Day one 比赛 赛后聊天 下午讲题 下午讲课 晚上 Day two 比赛 赛后聊天 下午讲题 下午讲课 晚上 Day thre ...

  5. Cobbler自定义标题及菜单密码

    sha1pass mypassword || openssl passwd -1 -salt sXiKzkus mypassword $1$sXiKzkus$x12Z3ZaiC34GhceLH5LXw ...

  6. VMware虚拟化与Kubernetes(K8s)类比阐述-适合VMware用户

    概述 容器技术是最近几年非常热门的技术,它似乎就是为云端的应用量身定制的,所以它也被贴上了云原生应用 (Cloud Native Application) 技术的标签.目前最为流行的容器管理调度平台是 ...

  7. 网络安全-WEB基础,burpsuite,WEB漏洞

    1. web基础 HTTP: GET POST REQUEST RESPONSE... JDK robots.txt 网页源代码/注释 目录扫描--御剑,dirmap 端口信息--nmap 备份文件- ...

  8. mybatis(二)全局配置mybatis-config.xml

    转载:https://www.cnblogs.com/wuzhenzhao/p/11092526.html 大部分时候,我们都是在Spring 里面去集成MyBatis.因为Spring 对MyBat ...

  9. 2019牛客多校第六场H Pair(数位DP 多个数相关)题解

    题意: 传送门 给你\(A,B,C\),要求你给出有多少对\((x, y)\)满足\(x\in [1,A],y\in [1,B]\),且满足以下任意一个条件:\(x \& y > C\) ...

  10. bzoj1013球形空间产生器sphere 高斯消元(有系统差的写法

    Description 有一个球形空间产生器能够在n维空间中产生一个坚硬的球体.现在,你被困在了这个n维球体中,你只知道球面上n+1个点的坐标,你需要以最快的速度确定这个n维球体的球心坐标,以便于摧毁 ...