溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

es6新增循環(huán)怎么使用

發(fā)布時間:2022-11-08 09:41:23 來源:億速云 閱讀:154 作者:iii 欄目:web開發(fā)

本篇內(nèi)容介紹了“es6新增循環(huán)怎么使用”的有關(guān)知識,在實(shí)際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

es6新增循環(huán)語句有一個:“for of”循環(huán)。“for..of”語句可循環(huán)遍歷整個對象,是在迭代器生產(chǎn)的一系列值的循環(huán);“for..of”循環(huán)的值必須是一個iterable(可迭代的),語法“for(當(dāng)前值 of 數(shù)組){...}”。for-of循環(huán)不僅支持?jǐn)?shù)組,還支持大多數(shù)類數(shù)組對象;它也支持字符串遍歷,會將字符串視為一系列Unicode字符來進(jìn)行遍歷。

以前for循環(huán),for in循環(huán);而ES6新增循環(huán):for of 循環(huán):遍歷(迭代,循環(huán))整個對象。

for..of

ES6新增了一個for..of循環(huán),在迭代器生產(chǎn)的一系列值的循環(huán)。for..of循環(huán)的值必須是一個iterable。

var a = ["a", "b","c","d","e"]
for(var idx in a){
    console.log(idx)
}
// 0 1 2 3 4
for(var val of a){
    console.log(val)
}
// a b c d e

for..in在數(shù)組a的鍵/索引上循環(huán),for..ofa的值上循環(huán)。

ES6之前的代碼

var a = ["a", "b","c","d","e"]
for(var val, ret, it = a[Symbol.iterator]();(ret=it.next()) && !ret.done){
    val = ret.value
    console.log(val)
}
// a b c d e

在底層,for..of循環(huán)向iterable請求一個迭代器,然后反復(fù)調(diào)用這個迭代器把它產(chǎn)生的值賦給循環(huán)迭代變量。

JavaScript默認(rèn)為iterable的標(biāo)準(zhǔn)內(nèi)建值包括:

  • Array

  • Strings

  • Generators

  • Collections/TypedArrays

字符串迭代方式

for(var c of "hello"){
    console.log(c)
}
// h e l l o

原生字符串值被強(qiáng)制類型轉(zhuǎn)換到等價的String封裝對象中,它是一個iterable

for(XYZ of ABC)

對于XYZ這個位置既可以是賦值表達(dá)式,也可以是聲明。下面看個賦值表達(dá)式的例子:

var o = {}
for(o.a of [1,2,3]){
    console.log(o.a)
}
o // {a:3}
for({x:o.a} of [{x:1},{x:2},{x:3}]){
    console.log(o.a)
}
o // {a:3}

通過break,continue,return提前終止循環(huán)。

自定義迭代器

通過對底層的了解,for..ofiterable請求一個迭代器,然后反復(fù)調(diào)用這個迭代器把它產(chǎn)生的值賦給循環(huán)迭代變量。那么我可以自定義一個iterable

var o = {
    [Symbol.iterator](){
        return this
    },
    next(){
        if(!val){
            val = 1
        }else{
            val ++
        }
        return {value:val, done:val== 6}
    }
}
for(var val of o[Symbol.iterator]()){
    console.log(val)
}

由此可見,自定義迭代器滿足兩個條件,[Symbol.iterator]屬性,返回的對象中有next方法,next方法返回值必須是{value:xx,done:xx}的形式,如果遇到done:true,則循環(huán)結(jié)束。

結(jié)語:以上就是for..of循環(huán)的全部內(nèi)容,它可以循環(huán)可迭代對象。

擴(kuò)展知識:為什么要引進(jìn) for-of?

要回答這個問題,我們先來看看ES6之前的 3 種 for 循環(huán)有什么缺陷:

  • forEach 不能 break 和 return;

  • for-in 缺點(diǎn)更加明顯,它不僅遍歷數(shù)組中的元素,還會遍歷自定義的屬性,甚至原型鏈上的屬性都被訪問到。而且,遍歷數(shù)組元素的順序可能是隨機(jī)的。

所以,鑒于以上種種缺陷,我們需要改進(jìn)原先的 for 循環(huán)。但 ES6 不會破壞你已經(jīng)寫好的 JS 代碼。目前,成千上萬的 Web 網(wǎng)站依賴 for-in 循環(huán),其中一些網(wǎng)站甚至將其用于數(shù)組遍歷。如果想通過修正 for-in 循環(huán)增加數(shù)組遍歷支持會讓這一切變得更加混亂,因此,標(biāo)準(zhǔn)委員會在 ES6 中增加了一種新的循環(huán)語法來解決目前的問題,即 for-of 。

那 for-of 到底可以干什么呢?

  • 跟 forEach 相比,可以正確響應(yīng) break, continue, return。

  • for-of 循環(huán)不僅支持?jǐn)?shù)組,還支持大多數(shù)類數(shù)組對象,例如 DOM nodelist 對象。

  • for-of 循環(huán)也支持字符串遍歷,它將字符串視為一系列 Unicode 字符來進(jìn)行遍歷。

  • for-of 也支持 Map 和 Set (兩者均為 ES6 中新增的類型)對象遍歷。

總結(jié)一下,for-of 循環(huán)有以下幾個特征:

  • 這是最簡潔、最直接的遍歷數(shù)組元素的語法。

  • 這個方法避開了 for-in 循環(huán)的所有缺陷。

  • 與 forEach 不同的是,它可以正確響應(yīng) break、continue 和 return 語句。

  • 其不僅可以遍歷數(shù)組,還可以遍歷類數(shù)組對象和其他可迭代對象。

但需要注意的是,for-of循環(huán)不支持普通對象,但如果你想迭代一個對象的屬性,你可以用
for-in 循環(huán)(這也是它的本職工作)。

最后要說的是,ES6 引進(jìn)的另一個方式也能實(shí)現(xiàn)遍歷數(shù)組的值,那就是 Iterator。上個例子:

const arr = ['a', 'b', 'c'];
const iter = arr[Symbol.iterator]();
 
iter.next() // { value: 'a', done: false }
iter.next() // { value: 'b', done: false }
iter.next() // { value: 'c', done: false }
iter.next() // { value: undefined, done: true }

前面的不多說,重點(diǎn)描述for-of

for-of循環(huán)不僅支持?jǐn)?shù)組,還支持大多數(shù)類數(shù)組對象,例如DOM NodeList對象。

for-of循環(huán)也支持字符串遍歷,它將字符串視為一系列的Unicode字符來進(jìn)行遍歷:

window.onload=function(){ 
   const arr = [55,00, 11, 22];
   arr.name = "hello";
  // Array.prototype.FatherName = 'FatherName';
   /*for(let key in arr){
    console.log('key='+key+',key.value='+arr[key]);
   }*/
   /* arr.forEach((data) => {console.log(data);});*/
  /* arr.forEach((data,index,arr) => {console.log(data+','+index+','+arr);});*/
  /*for(let key of arr){
    console.log(key);
  }*/
  var string1 = 'abcdefghijklmn';
  var string2 = 'opqrstuvwxyc';
  const stringArr = [string1,string2];
  for(let key of stringArr){
    console.log(key);
  }
  for(let key of string1){
    console.log(key);
  }
}

結(jié)果:

es6新增循環(huán)怎么使用

現(xiàn)在,只需記住:

  • 這是最簡潔、最直接的遍歷數(shù)組元素的語法

  • 這個方法避開了for-in循環(huán)的所有缺陷

  • 與forEach()不同的是,它可以正確響應(yīng)break、continue和return語句

for-in循環(huán)用來遍歷對象屬性。

for-of循環(huán)用來遍歷數(shù)據(jù)—例如數(shù)組中的值。

它同樣支持Map和Set對象遍歷。

Map和Set對象是ES6中新增的類型。ES6中的Map和Set和java中并無太大出入。

SetMap類似,也是一組key的集合,但不存儲value。由于key不能重復(fù),所以,在Set中,沒有重復(fù)的key。

要創(chuàng)建一個Set,需要提供一個Array作為輸入,或者直接創(chuàng)建一個空Set

var s1 = new Set(); // 空Set
var s2 = new Set([1, 2, 3]); // 含1, 2, 3

es6新增循環(huán)怎么使用

重復(fù)元素在Set中自動被過濾:

var s = new Set([1, 2, 3, 3, '3']);
console.log(s); // Set {1, 2, 3, "3"}

es6新增循環(huán)怎么使用

通過add(key)方法可以添加元素到Set中,可以重復(fù)添加,但不會有效果:

var s = new Set([1, 2, 3]);
s.add(4);
s; // Set {1, 2, 3, 4}
s.add(4);
s; // Set {1, 2, 3, 4}

通過delete(key)方法可以刪除元素:

var s = new Set([1, 2, 3]);
s; // Set {1, 2, 3}
s.delete(3);
s; // Set {1, 2}

Set對象可以自動排除重復(fù)項

var string1 = 'abcdefghijklmn';
  var string2 = 'opqrstuvwxyc';
  var string3 = 'opqrstuvwxyc';
  var string4 = 'opqrstuvwxyz';
 
  const stringArr = [string1,string2,string3,string4];
 
 
 var newSet = new Set(stringArr);
  for(let key of newSet){
    console.log(key);
  }

結(jié)果:

es6新增循環(huán)怎么使用

Map對象稍有不同:內(nèi)含的數(shù)據(jù)由鍵值對組成,所以你需要使用解構(gòu)(destructuring)來將鍵值對拆解為兩個獨(dú)立的變量:

for (var [key, value] of phoneBookMap) {   
console.log(key + "'s phone number is: " + value);
}

示例

var m = new Map([[1, 'Michael'], [2, 'Bob'], [3, 'Tracy']]);
  var map = new Map([['1','Jckey'],['2','Mike'],['3','zhengxin']]);
  map.set('4','Adam');//添加key-value
  map.set('5','Tom');
  map.set('6','Jerry');
  console.log(map.get('6'));
  map.delete('6');
   console.log(map.get('6'));
  for(var [key,value] of map) {
    console.log('key='+key+' , value='+value);
  }

結(jié)果:

es6新增循環(huán)怎么使用

“es6新增循環(huán)怎么使用”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

es6
AI