本篇內(nèi)容介紹了“es6新增循環(huán)怎么使用”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!
為建始等地區(qū)用戶提供了全套網(wǎng)頁設(shè)計制作服務(wù),及建始網(wǎng)站建設(shè)行業(yè)解決方案。主營業(yè)務(wù)為成都做網(wǎng)站、成都網(wǎng)站建設(shè)、成都外貿(mào)網(wǎng)站建設(shè)、建始網(wǎng)站設(shè)計,以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會得到認(rèn)可,從而選擇與我們長期合作。這樣,我們也可以走得更遠(yuǎn)!
es6新增循環(huán)語句有一個:“for of”循環(huán)?!癴or..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))整個對象。
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..of
在a
的值上循環(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
原生字符串值被強制類型轉(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..of
向iterable
請求一個迭代器,然后反復(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)可迭代對象。
要回答這個問題,我們先來看看ES6之前的 3 種 for 循環(huán)有什么缺陷:
forEach 不能 break 和 return;
for-in 缺點更加明顯,它不僅遍歷數(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)的另一個方式也能實現(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 }
前面的不多說,重點描述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é)果:
現(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中并無太大出入。
Set
和Map
類似,也是一組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
重復(fù)元素在Set中自動被過濾:
var s = new Set([1, 2, 3, 3, '3']);
console.log(s); // Set {1, 2, 3, "3"}
通過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é)果:
Map對象稍有不同:內(nèi)含的數(shù)據(jù)由鍵值對組成,所以你需要使用解構(gòu)(destructuring)來將鍵值對拆解為兩個獨立的變量:
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)怎么使用”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!