1 遍歷數(shù)組通常用for循環(huán)
ES5的話也可以使用forEach,ES5具有遍歷數(shù)組功能的還有map、filter、some、every、reduce、reduceRight等,只不過他們的返回結(jié)果不一樣。但是使用foreach遍歷數(shù)組的話,使用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會遍歷數(shù)組所有的可枚舉屬性,包括原型。例如上栗的原型方法method和name屬性
所以for in更適合遍歷對象,不要使用for in遍歷數(shù)組。
那么除了使用for循環(huá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 遍歷對象
遍歷對象 通常用for in來遍歷對象的鍵名
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án)內(nèi)部判斷一下,hasOwnPropery方法可以判斷某屬性是否是該對象的實(shí)例屬性
for (var key in myObject) {
if(myObject.hasOwnProperty(key)){
console.log(key);
}
}
同樣可以通過ES5的Object.keys(myObject)獲取對象的實(shí)例屬性組成的數(shù)組,不包括原型方法和屬性
Object.prototype.method=function(){
console.log(this);
}
var myObject={
a:1,
b:2,
c:3
}
for..of適用遍歷數(shù)/數(shù)組對象/字符串/map/set等擁有迭代器對象的集合.但是不能遍歷對象,因?yàn)闆]有迭代器對象.與forEach()不同的是,它可以正確響應(yīng)break、continue和return語句
for-of循環(huán)不支持普通對象,但如果你想迭代一個對象的屬性,你可以用for-in循環(huán)(這也是它的本職工作)或內(nèi)建的Object.keys()方法:
for (var key of Object.keys(someObject)) {
console.log(key + ": " + someObject[key]);
}
遍歷map對象時適合用解構(gòu),例如;
for (var [key, value] of phoneBookMap) {
console.log(key + "'s phone number is: " + value);
}
附:跳出循環(huán)
foreach 不能終止或跳過循環(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
}
文章來源:田珊珊個人博客
來源地址:http://www.tianshan277.com/756.html
申請創(chuàng)業(yè)報道,分享創(chuàng)業(yè)好點(diǎn)子。點(diǎn)擊此處,共同探討創(chuàng)業(yè)新機(jī)遇!