當(dāng)前位置:首頁(yè) >  站長(zhǎng) >  編程技術(shù) >  正文

for……in for……of 區(qū)別

 2020-11-17 13:39  來(lái)源: 田珊珊個(gè)人博客   我來(lái)投稿 撤稿糾錯(cuò)

  域名預(yù)訂/競(jìng)價(jià),好“米”不錯(cuò)過(guò)

1 遍歷數(shù)組通常用for循環(huán)

ES5的話(huà)也可以使用forEach,ES5具有遍歷數(shù)組功能的還有map、filter、some、every、reduce、reduceRight等,只不過(guò)他們的返回結(jié)果不一樣。但是使用foreach遍歷數(shù)組的話(huà),使用break不能中斷循環(huán),使用return也不能返回到外層函數(shù)。

Array.prototype.method=function(){

console.log(this.length);

}

var myArray=[1,2,4,5,6,7]

myArray.name="數(shù)組"

for (var index in myArray) {

console.log(myArray[index]);

}

2 for in遍歷數(shù)組的毛病

1.index索引為字符串型數(shù)字,不能直接進(jìn)行幾何運(yùn)算

2.遍歷順序有可能不是按照實(shí)際數(shù)組的內(nèi)部順序

3.使用for in會(huì)遍歷數(shù)組所有的可枚舉屬性,包括原型。例如上栗的原型方法method和name屬性

所以for in更適合遍歷對(duì)象,不要使用for in遍歷數(shù)組。

那么除了使用for循環(huán),如何更簡(jiǎn)單的正確的遍歷數(shù)組達(dá)到我們的期望呢(即不遍歷method和name),ES6中的for of更勝一籌.

Array.prototype.method=function(){

console.log(this.length);

}

var myArray=[1,2,4,5,6,7]

myArray.name="數(shù)組";

for (var value of myArray) {

console.log(value);

}

for in遍歷的是數(shù)組的索引(即鍵名),而for of遍歷的是數(shù)組元素值。

for of遍歷的只是數(shù)組內(nèi)的元素,而不包括數(shù)組的原型屬性method和索引name

3 遍歷對(duì)象

遍歷對(duì)象 通常用for in來(lái)遍歷對(duì)象的鍵名

Object.prototype.method=function(){

console.log(this);

}

var myObject={

a:1,

b:2,

c:3

}

for (var key in myObject) {

console.log(key);

}

for in 可以遍歷到myObject的原型方法method,如果不想遍歷原型方法和屬性的話(huà),可以在循環(huán)內(nèi)部判斷一下,hasOwnPropery方法可以判斷某屬性是否是該對(duì)象的實(shí)例屬性

for (var key in myObject) {

if(myObject.hasOwnProperty(key)){

console.log(key);

}

}

同樣可以通過(guò)ES5的Object.keys(myObject)獲取對(duì)象的實(shí)例屬性組成的數(shù)組,不包括原型方法和屬性

Object.prototype.method=function(){

console.log(this);

}

var myObject={

a:1,

b:2,

c:3

}

for..of適用遍歷數(shù)/數(shù)組對(duì)象/字符串/map/set等擁有迭代器對(duì)象的集合.但是不能遍歷對(duì)象,因?yàn)闆](méi)有迭代器對(duì)象.與forEach()不同的是,它可以正確響應(yīng)break、continue和return語(yǔ)句

for-of循環(huán)不支持普通對(duì)象,但如果你想迭代一個(gè)對(duì)象的屬性,你可以用for-in循環(huán)(這也是它的本職工作)或內(nèi)建的Object.keys()方法:

for (var key of Object.keys(someObject)) {

console.log(key + ": " + someObject[key]);

}

遍歷map對(duì)象時(shí)適合用解構(gòu),例如;

for (var [key, value] of phoneBookMap) {

console.log(key + "'s phone number is: " + value);

}

附:跳出循環(huán)

foreach 不能終止或跳過(guò)循環(huán)

for of 支持跳出循環(huán)

const fruits = ['Apple','Banana','Orange','Mango'];

for(let fruit of fruits){

if(fruit === 'Orange'){

break;  //終止

}

console.log(fruit);  // Apple Banana

}

for(let fruit of fruits){

if(fruit === 'Orange'){

continue;  //跳出循環(huán)

}

console.log(fruit);  // Apple Banana Mango

}

文章來(lái)源:田珊珊個(gè)人博客

來(lái)源地址:http://www.tianshan277.com/756.html

申請(qǐng)創(chuàng)業(yè)報(bào)道,分享創(chuàng)業(yè)好點(diǎn)子。點(diǎn)擊此處,共同探討創(chuàng)業(yè)新機(jī)遇!

相關(guān)文章

熱門(mén)排行

信息推薦