平时自己在写一些小栗子的时候,用到的基本上是for循环,因为在学专业课(C,C++,JAVA,...)的时候用的最多的就是for循环,不过for循环的效率也是比较高的。

但是for循环在写的时候,涉及到length,index这几个变量,使用起来个人觉得还是有点复杂。

for-in循环

最近自己在复习高程的时候,也看了看for-in循环,这个循环是特别针对遍历对象属性的。

ECMAScript对象的属性没有顺序,因此通过for-in循环输出的属性名的顺序是不可预测的,所有属性都会被返回一次,但是返回的顺序因浏览器不同。

之前如果要迭代的对象的变量值为null或undefined,for-in语句会抛出错误。但是ECMAScript5更正了这一行为:对这种情况不再抛出错误,而只是不执行循环体。为了保证最大限度的兼容,建议使用for-in循环之前,先检测确认该对象的值不是null或undefined。

Array的真相

在JavaScript中,所有的东西可可以看作是一个对象,Array也是一个对象,Array的索引就是属性名。实际上,Array的索引也不是Number类型,而是String类型的。

每个Array也有一个length属性,导致看起来像是一个数组。但是length这个属性是不可枚举的,所以在使用for-in循环遍历Array时,没有length。

即使不在Array中添加新的属性,也不会只输出数组中的内容。

Array.prototype.father = "xiaoming";
const arr = [1,2,3];
arr.name = "hello world";
let index;
for(index in arr){
console.log("array["+index+"]:"+arr[index]);
}

// array[0]:1

// array[1]:2

// array[2]:3

// array[name]:hello world

// array[father]:xiaoming

for-in循环的每次迭代操作会同时搜索实例或者原型属性,for-in循环的每次迭代会产生很多开销。除非明确要迭代一个属性数量未知的对象,否则应该避免使用for-in循环

forEach循环

forEach循环是js高程上数组的一个方法,还有几个方法参看其他几个迭代方法

const arr = [];
arr[0] = "a";
arr[3] = "b";
arr[10] = "c";
arr.name = "Hello world";
arr.forEach((data, index, array) => {
console.log(data, index, array); //这里的index是Number类型,这里并没有遍历到name属性
});

// a 0 (11) ["a", empty × 2, "b", empty × 6, "c", name: "Hello world"]

// b 3 (11) ["a", empty × 2, "b", empty × 6, "c", name: "Hello world"]

// c 10 (11) ["a", empty × 2, "b", empty × 6, "c", name: "Hello world"]

forEach循环不会遍历原型链上的属性

for-of循环

这个是ES6新增的一个方法,用于解决for-in用来遍历数组出现的问题。

为什么要引进for-of循环呢?

  • forEach不能break和return
  • for-in缺点更加明显,不仅会遍历数组中的元素,还会遍历自定义的属性,甚至把原型链上的属性都被访问到。而且遍历数组元素的顺序可能是随机的。

for-of循环可以干什么呢?

  • 跟forEach相比,可以正确响应break,continue,return
  • for-of循环不仅支持数组,还支持大多数类数组对象,例如DOM nodelist对象
  • for-of循环也支持字符串遍历,将字符串视为一系列的Unicode字符来进行遍历
  • for-of也支持Map和Set(两者均为ES6中新增的类型)遍历。

    这是最直接、最简洁的遍历数组的方法

    这个方法避开了for-in循环的所有缺陷

    与forEach不同的是,可以使用break,continue,return语句

    不仅可以遍历数组,还可以遍历类数组对象和其他可迭代对象。

    但是需要注意的是for-of不遍历普通对象,ES6引进的另一个方式也能实现遍历数组的值,那就是Iterator。

这里我只是简单总结了一点点,自己也认真看了书上的知识,推荐一篇写的很好的。https://zhuanlan.zhihu.com/p/23812134?utm_source=tuicool&utm_medium=referral

最新文章

  1. Linux下访问网站
  2. php--tp中页面之间的跳转
  3. Mac OX 隐藏文件夹,文件,应用,磁盘的2种方法 hide finder folder, file, application, volume in 2 ways
  4. [AngularJS] Javascript scope and AngularJS $scope
  5. [liu yanling]软件测试分为哪几个计划过程阶段
  6. SAP的 消息 弹出窗口(备忘)
  7. 开地址哈希表(Hash Table)的原理描述与冲突解决
  8. C#中public、private、protected等关键字说明
  9. 关于H5从PC端切换到移动端,屏幕显示内容由横向转为竖向的研究!
  10. centos7入门
  11. 应用通信-方案二:Feign
  12. 【转】给DataTable和DataRow扩展方法,直接转换为对象集合或对象
  13. win10打文件预览功能
  14. 在.net core 2.0中生成exe文件
  15. RabbitMQ :VHost,Exchanges, Queues,Bindings and Channels
  16. 《Are your lights on?》读后感
  17. text-overflow修剪文本,以省略号显示
  18. $.when()方法翻译2
  19. Content to Node: Self-Translation Network Embedding
  20. Win10-64位 免安装版Mysql8下载安装运行

热门文章

  1. Java的Integer常量池和String常量池
  2. 測試 battery capacity curve 的負載
  3. ZZ:Solaris 10 软件包分析
  4. c++设计模式系列----builder模式
  5. 2017多校第4场 HDU 6078 Wavel Sequence DP
  6. Jmeter接口测试示例
  7. 数据库索引(Index)【未完待续】
  8. python安装numpy和scipy的资源
  9. stl 学习笔记
  10. AIOps实践三板斧:从可视化、自动化到智能化