欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

ES6入門教程之Iterator與for...of循環(huán)詳解

 更新時間:2017年05月17日 11:44:29   作者:Dragon_GL  
最近在學(xué)習(xí)ES6,剛剛看到Iterator和for...of循環(huán)這一章,所以想要跟大家略微分享一下,下面這篇文章主要給大家介紹了關(guān)于ES6入門學(xué)習(xí)中Iterator與for...of循環(huán)的相關(guān)資料,不足之處還望大家多多指正,需要的朋友們可以參考學(xué)習(xí)。

本文主要介紹了關(guān)于ES6中Iterator與for...of循環(huán)的相關(guān)內(nèi)容,分享出來供大家參考學(xué)習(xí),需要的朋友們下面來一起看看詳細的介紹:

一、Iterator(遍歷器)

遍歷器(Iterator)是一種協(xié)議,任何對象只要部署了這個協(xié)議,就可以完成遍歷操作。在ES6中遍歷操作特質(zhì)for….of循環(huán)。

它的作用主要有兩個:

  • 為遍歷對象的屬性提供統(tǒng)一的接口。
  • 使對象的屬性能夠按次序排列。

ES6的遍歷器協(xié)議規(guī)定,部署了next方法的對象,就具備了遍歷器功能。next方法必須返回一個包含value和done兩個屬性的對象。value屬性是當前遍歷的位置的值,而done屬性是一個布爾值,用來表示遍歷是否結(jié)束。

 function makeIterator(array) {
  var nextIndex = 0;

  return {
   next: function() {
    return nextIndex < array.length ?
     {value: array[nextIndex++], done: false} :
     {value: undefined, done: true};
   }
  }
 }

 var it = makeIterator(['a', 'b']);
 it.next().value; //'a'
 it.next().value; //'b'
 it.next().done; // true

在上面代碼片段中,定義了一個makeIterator函數(shù),它的作用是返回一個遍歷器對象,用來遍歷參數(shù)數(shù)組。特別需要注意的是next返回值的構(gòu)造。

下面,再看看一個遍歷器的示例代碼片段:

 function idMaker() {
  var index = 0;
   return {
   next: function() {
    return {value: index++, done: false};
   }
   }
 }

 var it = idMaker();
 it.next().value; //'0'
 it.next().value; //'1'
 it.next().value; //'2'

二、for…of 循環(huán)

在ES6中,一個對象只要部署了next方法,就被視為是具有了iterator接口,就可以用for…of循環(huán)遍歷它的值。

 function idMaker() {
  var index = 0;
  return {
   next: function() {
    return {value: index++, done: false};
   }
  }
 }

 for (var n of it) {
  if (n > 5) {
   break;
   console.log( n );
  }
 }
 //0
 //1
 //2
 //3
 //4
 //5

上面的代碼說明,for….of默認從0開始循環(huán)。

數(shù)組原生具備iterator接口

 const arr = [1, 5, 3, 9];
 for (let v of arr) {
  console.log( v );
 }
 //1
 //5
 //3
 //9

相比較,Js原有的for…in循環(huán),只能獲得對象的鍵名,不能直接獲取鍵值。ES6提供了for…of循環(huán),允許遍歷獲取鍵值。

 var arr = ['a', 'b', 'c', 'd'];

 for (a in arr) {
  console.log( a );
 }
 //0
 //1
 //2
 //3

 for (a of arr) {
  console.log( a );
 }
 //0
 //1
 //2
 //3

上面的代碼片段表明,for…in循環(huán)讀取鍵名,而for…of循環(huán)讀取鍵值。

對于Set和Map結(jié)構(gòu)的數(shù)據(jù),可以直接使用for…of循環(huán)。

 var name = ['S', 'D', 'J', 'Z', 'G', 'G', 'G'];
 for ( var e of name) {
  console.log( e );
 }
 //S
 //D
 //J
 //Z
 //G


 var es6 = new Map();
 es6.set('edition', 6);
 es6.set('committee', 'TC39');
 es6.set('standard', 'ECMA-262');
 for(var [name, value] of es6) {
   console.log(name + ": " + value);
 }
 // edition: 6
 // commttee: TC39
 // standard: ECMA-262

在上面的代碼片段中,演示了如何遍歷Set結(jié)構(gòu)和Map結(jié)構(gòu),后者是同是遍歷鍵名和鍵值。

對于普通的對象,for...of結(jié)構(gòu)不能直接使用,否則則會報錯。必須項部署iterator接口才能使用。但是,在這種情況下,for...in循環(huán)依然可以遍歷鍵名。

 var es6 = {
  name: "G.Dragon",
  year: 22,
  love: "coding"
 };

 for (e in es6) {
  console.log( e );
 }
 //name
 //year
 //love

 for( e of es6) {
  console.log( e );
 }
 // TypeError: es6 is not iterable

最后,總結(jié)一下。for...of循環(huán)可以使用的范圍包括數(shù)組、類似數(shù)組的而對象(比如argument對象、DOM NodeList對象)、Set和Map結(jié)構(gòu)、后文的Generator對象,以及字符串。下面是使用for...of循環(huán)遍歷字符串和DOM NodeList對象的例子。

 // 字符串例子
 let str = "hello";

 for (let s of str) {
  console.log( s );
 }
 //h
 //e
 //l
 //l
 //o

 // DOM NodeList對象的例子
 let paras = document.getSelectorAll("p");
 for (let p of paras) {
  p.classList.add("test");
 }

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關(guān)文章

  • 基于bootstrap實現(xiàn)收縮導(dǎo)航條

    基于bootstrap實現(xiàn)收縮導(dǎo)航條

    這篇文章主要介紹了基于bootstrap實現(xiàn)收縮導(dǎo)航條的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • JavaScript常用基礎(chǔ)知識強化學(xué)習(xí)

    JavaScript常用基礎(chǔ)知識強化學(xué)習(xí)

    這篇文章主要介紹了JavaScript常用基礎(chǔ)知識強化學(xué)習(xí),需要的朋友可以參考下
    2015-12-12
  • BootstrapValidator實現(xiàn)表單驗證功能

    BootstrapValidator實現(xiàn)表單驗證功能

    這篇文章主要為大家詳細介紹了BootstrapValidator實現(xiàn)表單驗證功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-11-11
  • 微信小程序Echarts覆蓋正常組件問題解決

    微信小程序Echarts覆蓋正常組件問題解決

    這篇文章主要介紹了微信小程序Echarts覆蓋正常組件問題解決,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-07-07
  • 如何在TypeScript?中實現(xiàn)接口的類

    如何在TypeScript?中實現(xiàn)接口的類

    這篇文章主要介紹了TypeScript?中實現(xiàn)接口的類,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-03-03
  • 利用JavaScript實現(xiàn)ISO周日歷

    利用JavaScript實現(xiàn)ISO周日歷

    周日歷是日常生活中不常用到的歷法系統(tǒng),一般用于政府、商務(wù)的會計年度或者學(xué)校教學(xué)日歷中。本文將利用JavaScript制作個簡單的周日歷,感興趣的可嘗試一下
    2022-07-07
  • js中document.write和document.writeln的區(qū)別

    js中document.write和document.writeln的區(qū)別

    這篇文章主要介紹了js中document.write和document.writeln的區(qū)別,需要的朋友可以參考下
    2018-03-03
  • JavaScript初學(xué)者需要了解10個小技巧

    JavaScript初學(xué)者需要了解10個小技巧

    在之前的編程語言排行榜中,我們曾介紹過轉(zhuǎn)正在即的JavaScript語言,正如文章中闡明的那樣,JavaScript不僅是最具活力的腳本語言,還是是最有用的編程語言之一。
    2010-08-08
  • 詳解微信小程序之一鍵復(fù)制到剪切板

    詳解微信小程序之一鍵復(fù)制到剪切板

    這篇文章主要介紹了微信小程序一鍵復(fù)制到剪切板,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • Javscript調(diào)用iframe框架頁面中函數(shù)的方法

    Javscript調(diào)用iframe框架頁面中函數(shù)的方法

    這篇文章主要介紹了Javscript調(diào)用iframe框架頁面中函數(shù)的方法,可實現(xiàn)iframe之間傳值或修改值,是非常實用的技巧,需要的朋友可以參考下
    2014-11-11

最新評論