es6新特性 for...of

for...of 是什么

for...of 一种用于遍历数据结构的方法。它可遍历的对象包括数组,对象,字符串,set和map结构等具有iterator 接口的数据结构。

(上面这句话如果有看不懂的地方,自动忽略即可,后续会有章节介绍。)

下面就以大家熟悉的数组为例来介绍for...of。

遍历数组早就不是什么新鲜事,我们有好几种方法去完成,此时ES6给我们带来一个新的遍历方法for...of,难道它有更牛逼的地方?

接下来,我们先来看看几种传统的遍历数组的方式以及它们的缺陷。

方式一

1     var arr = [1,2,3,4,5];
2     for(let i = 0;i<arr.length;i++){
3         //...
4     }

方式一利用for循环来遍历数组的缺点就是:代码不够简洁。

下面介绍一个写法更加简洁的方式。

方式二

1     var arr = [1,2,3,4,5];
2     arr.forEach(function (value,index) {
3        //...
4     });
5     

利用forEach循环代码量少了很多,写法更加简洁,缺点就是:无法中断停止整个循环。

方式三

1     var arr = [1,2,3,4,5];
2     for(let i in arr){
3         //...
4     }
5     

for...in循环更常用于对象的循环,如果用于数组的循环,那么就要注意了,上述代码中每次循环中得到的i是字符串类型,而不是预料中的数字类型,要想对它进行运算,那得先要进行类型转换,造成不方便。

既然上面的几种方式都存在不足,新增的遍历方式for...of会比它们更好吗?答案是肯定的。

我们来看看for...of的是实现:

1    var arr = [1,2,3,4,5];
2     for(let value of arr){
3         console.log(value);
4     }
5     //打印结果:依次输出:1 2 3 4 5

看样子是不是有点眼熟,很像for...in?确实很像。它的实现跟for...in很类似。

我们列举一下for...of的优势:

  1. 写法比for循环简洁很多;
  2. 可以用break来终止整个循环,或者continute来跳出当前循环,继续后面的循环;
  3. 结合keys( )获取到循环的索引,并且是数字类型,而不是字符串类型。

    我们分别来展示一下上述的几个优点:

循环可以终止

1  var arr = [1,2,3,4,5];
2     for(let value of arr){
3         if(value == 3){
4             //终止整个循环
5             break;
6         }
7         console.log(value);
8     }
9     //打印结果:1 2
 以上案例:用break实现了终止整个循环,不会继续后面的遍历,所以打印结果为:1  2。

可跳过当前循环

1   var arr = [1,2,3,4,5];
2     for(let value of arr){
3         if(value == 3){
4             //跳过当前循环,继续后面的循环
5             continue;
6         }
7         console.log(value);
8     }
9     //打印结果:1 2 4  5

用continue跳过当前循环,继续后面的循环,所以打印结果为:1  2  4  5。

得到数字类型的索引

1     var arr = [1,2,3,4,5];
2     for(let index of arr.keys()){
3         console.log(index);
4     }
5     //打印结果:依次输出:0 1 2 3 4

使用数组的扩展keys( ),获取键名再遍历,得到的index是数字类型的。

此外,相比于for...in循环专门为对象设计,for...of循环的适用范围更广。

遍历字符串

for...of 支持字符串的遍历。

1     let word = "我是前端君";
2     for(let w of word){
3         console.log(w);
4     }
5     //打印结果:我  是  前  端  君

遍历DOM List

for...of支持类数组的遍历,例如DOM List。

 1     <p>1</p>
 2     <p>2</p>
 3     <p>3</p>
 4     //假设有3个p元素
 5     let pList = document.getElementsByTagName(‘p‘);
 6
 7     for(let p of pList){
 8         console.log(p);
 9     }
10     // 打印结果:<p>1</p>
11     //          <p>2</p>
12     //          <p>3</p>

for...of支持set和map解构的遍历,考虑到set和map我们还没学习,我们在后面章节一并讲解。

这节是近期最简短、最易学的一个章节了,希望大家多能看懂。

 本节小结

总结:for...of一种新的遍历方式,能遍历的对象有:数组,类数组对象,字符串,set和map结构等具有iterator接口的数据结构。而且for...in更适合用于对象的遍历。

时间: 2024-10-26 16:02:44

es6新特性 for...of的相关文章

ES6新特性

ES6新特性概览 箭头操作符 如果你会C#或者Java,你肯定知道lambda表达式,ES6中新增的箭头操作符=>便有异曲同工之妙.它简化了函数的书写.操作符左边为输入的参数,而右边则是进行的操作以及返回的值Inputs=>outputs. 我们知道在JS中回调是经常的事,而一般回调又以匿名函数的形式出现,每次都需要写一个function,甚是繁琐.当引入箭头操作符后可以方便地写回调了.请看下面的例子. var array = [1, 2, 3]; //传统写法 array.forEach(f

ES6新特性(函数默认参数,箭头函数)

ES6新特性之 函数参数的默认值写法 和 箭头函数. 1.函数参数的默认值 ES5中不能直接为函数的参数指定默认值,只能通过以下的变通方式:   从上面的代码可以看出存在一个问题,当传入的参数为0或者false时,会直接取到后面的值,而不是传入的这个参数值. 那怎么解决呢?对于上图的代码,可以通过判断是否传入了num参数,没有就用默认值:   这种做法还是很麻烦的,而ES6则直接在参数定义里面设置函数参数的默认值,而且不用担心传入参数是0或者false会出错了: 2.箭头函数 箭头函数用 =>

ES6新特性:Proxy代理器

ES6新特性:Proxy: 要使用的话, 直接在浏览器中执行即可, node和babel目前还没有Proxy的polyfill;,要使用的话,直接在浏览器中运行就好了, 浏览器的兼容性为:chrome>39或者firefox>18: Proxy的基本使用: Proxy如其名, 它的作用是在对象和和对象的属性值之间设置一个代理,获取该对象的值或者设置该对象的值, 以及实例化等等多种操作, 都会被拦截住, 经过这一层我们可以统一处理,我们可以认为它就是“代理器” ; Proxy是一个构造函数, 使

ES6新特性学习

ES6是ECMAScript 6的缩写简称,2015 年 6 月,ECMAScript 6 正式通过,成为国际标准.ES6带来的新功能涵盖面很广,还有很多很便利的功能.下面来记一下我接触到的几个新特性. 1.模板字符串,用反单引号包起来,可以实现字符串回车换行,也可以在字符串里拼接变量,${变量},很方便使用. var name="fanfan"; var age="20"; console.log("Hello,My name is "+nam

你不知道的JavaScript--Item24 ES6新特性概览

ES6新特性概览 本文基于lukehoban/es6features ,同时参考了大量博客资料,具体见文末引用. ES6(ECMAScript 6)是即将到来的新版本JavaScript语言的标准,代号harmony(和谐之意,显然没有跟上我国的步伐,我们已经进入中国梦版本了).上一次标准的制订还是2009年出台的ES5.目前ES6的标准化工作正在进行中,预计会在14年12月份放出正式敲定的版本.但大部分标准已经就绪,且各浏览器对ES6的支持也正在实现中.要查看ES6的支持情况请点此. 目前想要

JS篇 ES6新特性

注意: 1. Node环境下,--harmony参数启用ES6新特性,许多新特性只有在strict mode下才生效,因此使用"use strict"或者--use_strict,否则harmony没有被启用: 1. 块级作用域(Block scope) // Block scope function f1(){ console.log("Outside."); } (function(){ if(false){ // f1定义在if {}之内 function f

ES6新特性之模板字符串

ES6新特性概览  http://www.cnblogs.com/Wayou/p/es6_new_features.html 深入浅出ES6(四):模板字符串   http://www.infoq.com/cn/articles/es6-in-depth-template-string

ES6新特性概览

转自:http://www.cnblogs.com/Wayou/p/es6_new_features.html ES6学习可参考:http://es6.ruanyifeng.com/ 本文基于lukehoban/es6features ,同时参考了大量博客资料,具体见文末引用. ES6(ECMAScript 6)是即将到来的新版本JavaScript语言的标准,代号harmony(和谐之意,显然没有跟上我国的步伐,我们已经进入中国梦版本了).上一次标准的制订还是2009年出台的ES5.目前ES6

JavaScript学习--Item24 ES6新特性概览

ES6新特性概览 本文基于lukehoban/es6features ,同时参考了大量博客资料,具体见文末引用. ES6(ECMAScript 6)是即将到来的新版本JavaScript语言的标准,代号harmony(和谐之意,显然没有跟上我国的步伐,我们已经进入中国梦版本了).上一次标准的制订还是2009年出台的ES5.目前ES6的标准化工作正在进行中,预计会在14年12月份放出正式敲定的版本.但大部分标准已经就绪,且各浏览器对ES6的支持也正在实现中.要查看ES6的支持情况请点此. 目前想要

34.JS 开发者必须知道的十个 ES6 新特性

JS 开发者必须知道的十个 ES6 新特性 这是为忙碌的开发者准备的ES6中最棒的十个特性(无特定顺序): 默认参数 模版表达式 多行字符串 拆包表达式 改进的对象表达式 箭头函数 =&> Promise 块级作用域的let和const 类 模块化 注意:这个列表十分主观并且带有偏见,其他未上榜的特性并不是因为没有作用,我这么做只是单纯的希望将这份列表中的项目保持在十个. 首先,一个简单的JavaScript时间线,不了解历史的人也无法创造历史. 1995年:JavaScript以LiveS