Javascript中的遍历循环
1.for循环
对于数值索引的数组来说,可以使用标准的for循环来遍历值
const arr=[1,2,3,4]; for(let i=0;i<arr.length;i++){ console.log(i); }
2.for...in循环
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循环来遍历.
3.for...of循环
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
4.foreach(...)
**forEach()**
方法对数组的每个元素执行一次给定的函数。
const arr = ['a', 'b', 'c']; arr.forEach(element => console.log(element)); // a // b // c
arr.forEach(callback(currentValue [,index [,array]])[,thisArg])
5.some(...)
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
6.every(...)
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
以上就是JavaScript 中的六种循环方法的详细内容,更多关于JavaScript 循环的资料请关注其它相关文章!
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“JavaScript 中的六种循环方法”评论...
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新动态
20240523
20240523
- 群星.2001-水底乐园(刘以达作品集)【正东】【WAV+CUE】
- 贵族音乐《颂钵减压SPA 空灵疗心音乐精选》[FLAC/分轨][157.53MB]
- 群星《穿越西藏音乐经典》HIFI珍藏限量版 [APE+CUE][374M]
- 李克勤《极品之选》 环球SACD天碟系列 2002[DFF][2.1G]
- 群星《飞图超白金精选1-8》8CD[WAV+CUE]
- 离天边最近的声音-旦增尼玛《藏乡情HQCD》WAV
- 群星1990-怀旧好歌·老歌珍藏[台湾版][WAV+CUE]
- 容祖儿.2006-TEN.MOST.WANTED(加歌版)【英皇娱乐】【WAV+CUE】
- 林一峰.2022-OffTracks(EP)【LYFMUSIC】【FLAC分轨】
- 群星.2001-水底乐园(刘以达作品集)【正东】【WAV+CUE】
- 群星1990-怀旧粵语金曲珍藏版之三[日本版][WAV+CUE]
- 奔驰汽车音乐圣经《醇声典范[白金嗓子]男极声》[正版CD低速原抓WAV+CUE]
- 痛仰乐队.2000-这是个问题【京文】【WAV+CUE】
- 贵族音乐《迪士尼音乐 宝宝睡眠钢琴 古典竖琴摇篮曲》[320K/MP3][165.11BB]
- 贵族音乐《迪士尼音乐 宝宝睡眠钢琴 古典竖琴摇篮曲》[FLAC/分轨][195.67MB]