JavaScript中循环方法有哪些,你知道几个?
Admin 2021-05-24 群英技术资讯 1518 次浏览
js中的循环方法有哪些?关于在JavaScript 中的遍历循环的方法很多,下面给大家分享的是for循环、for...in循环、for...of循环、foreach(...)、some(...)、every(...)这六种循环,感兴趣的朋友可以参考学习。
对于数值索引的数组来说,可以使用标准的for循环来遍历值
const arr=[1,2,3,4];
for(let i=0;i<arr.length;i++){
console.log(i);
}
for...in循环可以用来遍历对象的可枚举属性列表(包括原型链上的属性)
const myObject={};
Object.defineProperty(myobject,"a",{
//可枚举
enumerable:true,
value:2,
})
Object.defineProperty(myobject,"b",{
//不可枚举
enumerable:false,
value:2,
})
for(let k in myObject){
console.log(k,myObject[k])
// a 2
}
//使用for...in循环是无法直接获得属性值的,因为它实际遍历的是对象中的所有可枚举属性,
//所以你需要手动获得属性值.
在数组上应用for...in循环,不仅仅会包含所有数值索引,还会包含所有可枚举属性。所以最好在对象上应用for...in循环。如果要遍历数组最好使用传统的for循环来遍历.
1.ES6新增的for...of循环
const arr=[1,2,3];
for(let value of arr){
console.log(value)
//1
//2
//3
}
for...of循环首先会向所有被访问的对象请求一个迭代器对象,然后通过调用迭代器对象的next()方法来遍历所有返回值。在数组中有内置的@@iterator,因此for...of可以直接应用在数组上。
使用内置的@@iterator遍历数组
const arr=[1,2,3];
//获取数组中的iterator对象:使用ES6中的符号Symbol.iterator来获取对象的@@iteraotr内部属性.
//@@iterator本身不是一个迭代器,而是一个返回迭代器对象的函数。
const it=arr[Symbol.iterator]();
it.next(); //{value:1,done:false}
it.next(); //{value:2,done:false}
it.next(); //{value:3,done:false}
it.next(); //{done:true}
//调用迭代器的next()方法会返回形式为{value:..,done:..}的值;
//value为当前的值,done是一个布尔值,表示是否还存在可以遍历的值
2.给对象定义@@iterator
const myObject={
a:2,
b:3
}
Object.defineProperty(myObject,Symbol.iterator,{
enumerable:false,
writeable:false,
configurable:true,
value:function(){
let o=this;
let idx=0;
//对象中的属性数组
let ks=Object.keys(o);
return{
value:o[ks[idx++]],
done:(idx>ks.length);
}
}
})
const it=myObject[Symbol.iterator]();
it.next(); //{value:2,done:false}
it.next(); //{value:3,done:false}
it.next(); //{done:true}
for(let value of myObject){
console.log(value);
}
// 2
// 3
**forEach()** 方法对数组的每个元素执行一次给定的函数。
const arr = ['a', 'b', 'c']; arr.forEach(element => console.log(element)); // a // b // c
arr.forEach(callback(currentValue [,index [,array]])[,thisArg])
some()是对数组中每一项运行给定函数,如果该函数对任一项返回true,则返回true。
var arr = [ 1, 2, 3, 4, 5, 6 ];
console.log( arr.some( function( item, index, array ){
console.log( 'item=' + item + ',index='+index+',array='+array );
return item > 3;
}));
// item=1,index=0,array=1,2,3,4,5,6
// item=2,index=1,array=1,2,3,4,5,6
// item=3,index=2,array=1,2,3,4,5,6
// item=4,index=3,array=1,2,3,4,5,6
// true
every()是对数组中每一项运行给定函数,如果该函数对每一项返回true,则返回true。
var arr = [ 1, 2, 3, 4, 5, 6 ];
console.log( arr.every( function( item, index, array ){
console.log( 'item=' + item + ',index='+index+',array='+array );
return item > 3;
}));
// item=1,index=0,array=1,2,3,4,5,6
// false
关于js 循环方法的介绍就到这,上述示例有一定的借鉴价值,有需要的朋友可以参考学习,希望本文对大家了解JavaScript的循环有帮助,更多js循环方法,可以关注其他文章。
文本转载自脚本之家
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
本篇文章给大家带来了关于javascript的相关知识,其中主要介绍了关于JavaScript对象的相关问题,对象是一组无序的相关属性和方法的集合,所有事物都是对象,例如字符串,数值,数组,函数等,下面一起来看一下,希望对大家有帮助。
这篇文章主要介绍了vue-router钩子函数实现路由守卫,对vue感兴趣的同学,可以参考下
JQuery复选框全选效果如何实现,具体代码如下,感兴趣的朋友可以参考。
这篇文章主要介绍了vue如何实现简易的双向数据绑定,帮助大家更好的理解和使用vue框架,感兴趣的朋友可以了解下
这篇文章给大家分享的是vue中数据响应式实现的内容,下文将给大家介绍为何要实现数据响应式及vue中的数据响应,文中示例代码介绍的非常详细,感兴趣的朋友接下来一起跟随小编看看吧。
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008