for循环
最原始的遍历,自Javascript诞生起就一直用的 就是for循环,它用来遍历数组
for ( 初始值 ; 结束条件 ; 循环变化值或自增 ) { 执行语句 };
初始值-->判断-->执行语句-->循环变化值-->判断-->执行语句-->判断-->跳出循环
for(var i = 0; i < *.length; i++){
用this代表触发当前事件的元素
}
for里用了一个函数,里面可以用i
for(var i=0;i
aInput[i].index=i; //这里的i并没有放在函数里所以可以是递增的数值
aInput[i].onclick=function(){
this.value=this.index; //这里是事先赋值的i值所以这里并不影响使用
}
}
想建立“匹配”"对应"关系,就用索引值
forEach
从ES5开始 Javascript内置了forEach方法 用来遍历数组,foreach 方法没办法使用 break 语句跳出循环,或者使用return从函数体内返回
arr.forEach(function(ele,index,arr){ },thisValue)
对数组中的每一个元素,执行一次提供的函数
- callback(ele) 函数
- ele :循环过程中的每一位元素
- index: 当前循环的元素对应的下标值
- arr : 调用forEach的当前数组
- thisArg: 控制当前callback中的this指向(一般写document)
该方法返回值是undefined
for...in循环
for(var key in obj){ }
对象obj,for获取不到长度和内容,需要用for...in循环
循环设计之初,是给普通以字符串的值为key的对象使用的。而非数组,for - in也可用来循环数组,但一般并不推荐
1.index 值 会是字符串(String)类型
2.循环不仅会遍历数组元素,还会遍历任意其他自定义添加的属性,如,objArr上面包含自定义属性,objArr.name,那这次循环中
也会出现此name属性
var obj ={x:20,y:30,z:40} // 对象
for(var v in obj){ // 声明一个key变量用于代表obj里的key,名字随便起,var key in obj是整句
console.log(v) // 0 1 2 length
console.log(obj[v]) // 20 30 40
}
var arr = [10,20,30,40] // 数组,一般建议for循环
for(var v in arr){
console.log(v) // 0 1 2 3 length
console.log(arr[v]) // 10 20 30 40
}
for...of循环
1.可以避免所有 for-in 循环的陷阱
2.不同于 forEach(),可以使用 break, continue 和 return
3.for-of 循环不仅仅支持数组的遍历。同样适用于很多类似数组的对象
4.它也支持字符串的遍历
5.for-of 并不适用于处理原有的原生对象
for...in:以原始插入的顺序迭代对象的可枚举属性
for...of:根据迭代对象的迭代器具体实现迭代对象数据
但是可以循环一个拥有enumerable属性的对象。
for in 和 for of的区别
for in 的特点
结合上面的两个例子,分析得出:
for ... in 循环返回的值都是数据结构的键值名。
遍历对象返回的对象的key值,遍历数组返回的数组的下标(key)。
for ... in 循环不仅可以遍历数字键名,还会遍历原型上的值和手动添加的其他键。如——例3
特别情况下, for ... in 循环会以任意的顺序遍历键名
总结一句:for in循环特别适合遍历对象
for of 特点
for of 循环用来获取一对键值对中的值,而 for in 获取的是键名
一个数据结构只要部署了 Symbol.iterator 属性, 就被视为具有 iterator接口, 就可以使用 for of循环。
例1这个对象,没有 Symbol.iterator这个属性,所以使用 for of会报 obj is not iterable
for of 不同与 forEach, 它可以与 break、continue和return 配合使用,也就是说 for of 循环可以随时退出循环。
提供了遍历所有数据结构的统一接口
哪些数据结构部署了 Symbol.iteratoer属性了呢?
只要有 iterator 接口的数据结构,都可以使用 for of循环。
数组 Array
Map
Set
String
arguments对象
Nodelist对象, 就是获取的dom列表集合
以上这些都可以直接使用 for of 循环。 凡是部署了 iterator 接口的数据结构也都可以使用数组的 扩展运算符(...)、和解构赋值等操作。
我也想让对象可以使用 for of循环怎么办?使用 Object.keys() 获取对象的 key值集合后,再使用 for of
break 打破
终止当前循环,包括break之后的代码也会被停止运行,并跳出循环
for双循环加break,不能停止双循环
continue 持续
终止当前循环,包括continue之后的代码也会被停止,但不是跳出循环,循环会在之后,继续执行