for,forEach数组字符串 / 对象for...in / 对象取值for...of / 循环里用this / 函数不可以用i要自定义索引 / break打破 / continue持续

for循环

        最原始的遍历,自Javascript诞生起就一直用的 就是for循环,它用来遍历数组

for ( 初始值 ; 结束条件 ; 循环变化值或自增 ) { 执行语句 };

        初始值-->判断-->执行语句-->循环变化值-->判断-->执行语句-->判断-->跳出循环

        for(var i = 0; i < *.length; i++){

                用this代表触发当前事件的元素

        }


for里用了一个函数,里面可以用i

        for(var i=0;i<aInput.length;i++){

                aInput[i].index=i;        //这里的i并没有放在函数里所以可以是递增的数值

        aInput[i].οnclick=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之后的代码也会被停止,但不是跳出循环,循环会在之后,继续执行


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值