for蓝厌、forEach 、for in古徒、for of 循環(huán)的區(qū)別

  1. for:遍歷數(shù)組

//對象數(shù)組
var arr = [ {Monday: '星期一', Tuesday: '星期二', Wednesday: '星期三'} ]
for (var i=0; i<arr.length;i++){ // i是下標(biāo)(索引)
console.log(i)
console.log(arr[i])
}
結(jié)果:0
{Monday: '星期一', Tuesday: '星期二', Wednesday: '星期三'}

//數(shù)組
var arr = ["星期一","星期二","星期三"]
for (var j=0; j<arr.length;j++){// j是下標(biāo)(索引)
console.log(j)
console.log(arr[j])
}

結(jié)果:
0
星期一
1
星期二
2
星期三


  1. forEach:遍歷數(shù)組拓提,但不能使用break、continue和return語句

//對象數(shù)組
var arr = [
{guangzhou: '廣州', shanghai: '上海', beijing: '北京'},
{Monday: '星期一', Tuesday: '星期二', Wednesday: '星期三'}
]
arr.forEach(function(value,index){ //第一個參數(shù)是值隧膘,第二個參數(shù)是下標(biāo)(索引)
console.log(value)
console.log(index)
})
結(jié)果:{guangzhou: '廣州', shanghai: '上海', beijing: '北京'},
0
{Monday: '星期一', Tuesday: '星期二', Wednesday: '星期三'}
1

//數(shù)組
var arr = ["星期一","星期二","星期三"];
arr.forEach(function(value,index){//第一個參數(shù)是值代态,第二個參數(shù)是下標(biāo)(索引)
console.log(value)
console.log(index)
})
結(jié)果:
星期一
0
星期二
1
星期三
2


for…in:遍歷數(shù)組索引、對象的屬性
使用for…in遍歷時疹吃,原型鏈上的所有屬性都將被訪問
例如:

//數(shù)組
var arr = ["星期一","星期二","星期三"];
Array.prototype.something = ["放假","休息咯"];
for (var i in arr){ // i是下標(biāo)(索引)
console.log(arr[i])
}
結(jié)果:
星期一
星期二
星期三
["放假","休息咯"]

如果把該例子的數(shù)組蹦疑,寫成像上面的對象數(shù)組,效果與數(shù)組也是一樣的萨驶,就不再次用對象數(shù)組來測試了歉摧。

//對象
var obj = {guangzhou: '廣州', shanghai: '上海', beijing: '北京'}
Object.prototype.something2={shenzhen:'深圳'}
for (var i in obj){
console.log(obj[i])
}
結(jié)果:廣州
上海
北京
{shenzhen:“深圳”}

解決方法:使用hasOwnProperty()
hasOwnProperty()方法可以檢測一個屬性是存在于實例中,還是存在于原型中腔呜。這個方法只在給定屬性存在于對象實例中時叁温,才會返回true。

//數(shù)組
var arr = ["星期一","星期二","星期三"];
Array.prototype.something = ["放假","休息咯"];
for (var i in arr){
if(arr.hasOwnProperty(i)){
console.log(arr[i])
}
}

結(jié)果:星期一
星期二
星期三

//對象
var obj = {guangzhou: '廣州', shanghai: '上海', beijing: '北京'}
Object.prototype.something2={shenzhen:'深圳'}
for (var i in obj){
if(obj.hasOwnProperty(i)){
console.log(obj[i])
}
}
結(jié)果:廣州
上海
北京


for…of:遍歷數(shù)組的值

//數(shù)組
var arr = ["星期一","星期二","星期三"];
for (var i of arr){ //i是值
console.log(i)
}
//對象
var obj = {guangzhou: '廣州', shanghai: '上海', beijing: '北京'}
for (var i of obj){ //i是值
console.log(i)
}
//對象會報錯:Uncaught TypeError: obj is not iterable
//不能遍歷一個普通的對象核畴,可以通過 內(nèi)建Object.keys() 方法讓 for..of 也支持
//我也還沒有試過膝但,這里就先不測試了,之后再研究下

結(jié)果:星期一
星期二
星期三
obj對象的結(jié)果:報錯谤草,obj is not iterable

總結(jié):
for(最原始的寫法)跟束、 forEach(ES5,但是它不支持使用break咖刃、continue和return語句)、for…of(ES6憾筏,循環(huán)數(shù)組的元素值)這三個是循環(huán)數(shù)組(對象數(shù)組)的嚎杨;
for…in循環(huán)數(shù)組索引、對象的屬性氧腰,但使用 for…in 原型鏈上的所有屬性都將被訪問枫浙,用 hasOwnProperty() 方法解決。

https://blog.csdn.net/demiling/article/details/83146361

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末古拴,一起剝皮案震驚了整個濱河市箩帚,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌黄痪,老刑警劉巖紧帕,帶你破解...
    沈念sama閱讀 218,122評論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡是嗜,警方通過查閱死者的電腦和手機(jī)愈案,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,070評論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來鹅搪,“玉大人站绪,你說我怎么就攤上這事±鍪粒” “怎么了恢准?”我有些...
    開封第一講書人閱讀 164,491評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長甫题。 經(jīng)常有香客問我馁筐,道長,這世上最難降的妖魔是什么幔睬? 我笑而不...
    開封第一講書人閱讀 58,636評論 1 293
  • 正文 為了忘掉前任眯漩,我火速辦了婚禮,結(jié)果婚禮上麻顶,老公的妹妹穿的比我還像新娘赦抖。我一直安慰自己,他們只是感情好辅肾,可當(dāng)我...
    茶點故事閱讀 67,676評論 6 392
  • 文/花漫 我一把揭開白布队萤。 她就那樣靜靜地躺著,像睡著了一般矫钓。 火紅的嫁衣襯著肌膚如雪要尔。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,541評論 1 305
  • 那天新娜,我揣著相機(jī)與錄音赵辕,去河邊找鬼。 笑死概龄,一個胖子當(dāng)著我的面吹牛还惠,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播私杜,決...
    沈念sama閱讀 40,292評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼蚕键,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了衰粹?” 一聲冷哼從身側(cè)響起锣光,我...
    開封第一講書人閱讀 39,211評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎铝耻,沒想到半個月后誊爹,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,655評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,846評論 3 336
  • 正文 我和宋清朗相戀三年替废,在試婚紗的時候發(fā)現(xiàn)自己被綠了箍铭。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,965評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡椎镣,死狀恐怖诈火,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情状答,我是刑警寧澤冷守,帶...
    沈念sama閱讀 35,684評論 5 347
  • 正文 年R本政府宣布,位于F島的核電站惊科,受9級特大地震影響拍摇,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜馆截,卻給世界環(huán)境...
    茶點故事閱讀 41,295評論 3 329
  • 文/蒙蒙 一充活、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧蜡娶,春花似錦混卵、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,894評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至宿接,卻和暖如春赘淮,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背睦霎。 一陣腳步聲響...
    開封第一講書人閱讀 33,012評論 1 269
  • 我被黑心中介騙來泰國打工梢卸, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人副女。 一個月前我還...
    沈念sama閱讀 48,126評論 3 370
  • 正文 我出身青樓蛤高,卻偏偏與公主長得像,于是被迫代替她去往敵國和親肮塞。 傳聞我的和親對象是個殘疾皇子襟齿,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,914評論 2 355

推薦閱讀更多精彩內(nèi)容