范文健康探索娱乐情感热点
投稿投诉
热点动态
科技财经
情感日志
励志美文
娱乐时尚
游戏搞笑
探索旅游
历史星座
健康养生
美丽育儿
范文作文
教案论文
国学影视

下班前几分钟,搞懂这6种for循环

  for 循环在平时开发中使用频率最高的,前后端数据交互时,常见的数据类型就是数组和对象,处理对象和数组时经常使用到 for 遍历,因此下班前花费几分钟彻底搞懂这 5 种 for 循环。它们分别为:forfor ... infor ... offor await .. offorEachmap
  一、各个 for 介绍
  1.1、for
  for 循环是出现最早,也是应用最普遍的一个遍历,能够满足绝大多的遍历。可以遍历 数组、对象、字符串,示例:// 遍历数组 var arr = [1, 2, 3] for (var i = 0; i < arr.length; i++){   console.log(arr[i]); }  //遍历对象 var obj = {   job: "web worker",   name:"前端代码女神" } for (var i = 0,keys = Object.keys(obj); i< keys.length; i++){   console.log(obj[keys[i]]) }  //遍历字符串 let str = "abc" for (var i = 0; i < str.length; i++){   console.log(str[i]) }
  1.2、for ... in
  for ... in 是在 ES5 中新增的,以任意顺序迭代一个对象的除 Symbol以外的 可枚举属性,包括继承的可枚举属性。 // 遍历数组 var arr = [1, 2, 3] for (var i in arr ){   console.log(i);//0 1 2   console.log(arr[i]);//1 2 3 }  //遍历对象 var obj = {   job: "web worker",   name:"前端代码女神" } for (var key in obj){   console.log(key)// job name   console.log(obj[key])// web worker  前端代码女神 }  //遍历字符串 let str = "abc" for (var i in str){   console.log(i) // 0 1 2   console.log(str[i]) // a b c }
  1.3、for ... of
  for ... of 语句在可迭代对象(包括 Array、Map、Set、String、TypedArray、arguments 对象等等)上创建一个迭代循环,调用自定义迭代钩子,并为每个不同属性的值执行语句。// 迭代 Array var arr = [1, 2, 3] for (var val of arr ){   console.log(val);// 1 2 3 }  //迭代 String let str = "abc" for (var val of str){   console.log(val) // a b c }  // 迭代 TypedArray - 一个类型化数组,描述了一个底层的二进制数据缓冲区! let iterable = new Uint8Array([0x00, 0xff]);  for (let value of iterable) {   console.log(value);//0 255 }  // 迭代 Map - 对象保存键值对,能够记住键的原始插入顺序 let map = new Map([["a",1],["b",2]]) for (let key of map) {   console.log("key",key)//["a",1] ["b",2]  } for (let [key,value] of map) {   console.log(key) // a b   console.log(value) // 1 2 }  // 迭代 Set let set = new Set([1,2,3,2,1]) for (let val of set) {   console.log(val)// 1 2 3 }
  1.4、for await...of
  创建一个循环,该循环遍历异步可迭代对象以及同步可迭代对象,包括内置的 String、Array,类数组对象(arguments 或 nodeList), TypedArray,  Map,  Set 和用户定义的异步/同步迭代器。它使用对象的每个不同属性的值调用要执行的语句来调用自定义迭代钩子。
  类似于  await 运算符一样,该语句只能在一个 async function 内部使用。 async function* asyncGenerator() {   var i = 0;   while (i < 3) {     yield i++;   } } (async function () {   for await (num of asyncGenerator()) {     console.log(num);// 0 1 2   } })();
  1.5、forEach
  forEach 是ES5版本发布的,按升序为数组中含有效值的每一项执行一次回调函数,那些已删除或者未初始化的项将被跳过(例如在稀疏数组上),一般认为是 普通for循环 的加强版。 // 遍历数组 var arr = [1, 2, 3] arr.forEach((item, index) => {   console.log(index);//0 1 2   console.log(item);// 1 2 3 })  //遍历对象 var obj = {   job: "web worker",   name:"前端代码女神" } var keys = Object.keys(obj) keys.forEach((key) => {   console.log(key)// job name   console.log(obj[key])// web worker  前端代码女神 })
  1.6、map
  遍历时可以返回一个新数组,新数组的结果是圆数组中每个元素都调用一次提供的函数后返回的值。// 遍历数组 var arr = [1, 2, 3] let newArr = arr.map((item) => item * 2) console.log(newArr);//[2,4,6]二、多个 for 之间区别
  2.1、使用场景差异
  for 循环是最早最原始的循环遍历语句,for 内部定义一个变量,按照条件进行循环遍历,通常是数组的长度,当超过长度时就停止循环,一般遍历的都是数组或类数组。遍历对象时,由于对象没有长度,所以使用 Object.keys() 获取对象的所有属性,以数组形式返回。
  for / in 主要是用来遍历对象上的可枚举属性,包括原型对象上的属性,按任意顺序进行遍历,遍历对象时获取到的是属性的键值,遍历的是数组,数组的下标当做键值。
  for / of 用于遍历可迭代对象的数据,包括 Array、Map、Set、String、TypedArray、arguments 对象等等。
  for await...of 用于遍历异步可迭代对象,该语句只能在一个 async function 内部使用。
  forEach 是 for 的加升级版,使用更简单,携带参数更多,但本质还是数组的循环,每个元素都执行一次回调,不会改变原数组。
  map 是给原数组每个元素都执行一次回调,返回一个新数组,不会改边原数组。
  2.2、功能差异
  forEach、map 不支持跳出循环,其他不支持。
  for await ... of 能够支持异步操作,其他的不支持。
  对于纯对象的遍历, for ... in 枚举更方便。
  对于数组遍历,如果不需要索引,直接使用 for...of 获取值,还可支持 break 或 return ;如果还需要索引,使用 forEach 更适合,但不支持 return。
  如果是一个数组映射成另一个数组,使用 map 最合适。
  2.3、性能差异
  在测试环境、测试数据条件一致的情况下,性能排序为:
  for > for of > forEach > map > for in
  for 因为没有额外的函数调用和上下文,所以性能是最快的。
  for ... of 具有 iterator 接口的数据结构,可以使用它来迭代成员,直接读取键值。
  forEach 是 for 的语法糖,还有许多的参数和上下文,因此会慢一些。
  map 因为它返回的是一个等长的全新数组,数组创建和赋值产生的性能开销较大。
  for...in 性能最差,因为需要列举对象的所有属性,有转化过程,开销比较大。
  三、for 的使用
  在项目开发中,我们应该根据实际需求,去选择一个合适的 for 遍历。以下是一些使用建议:如果需要把数据映射成另外一个数组,如变成对应布尔值,推荐使用 map ,不会修改原数组,使用语法简单。数组遍历时,可以使用 for 、forEach 或 for...of。遍历的是纯对象时,推荐使用 for ... in 。如果时需要对迭代器遍历,推荐使用 for ... of。如果是在数组中筛选符合条件的数组,使用 fillter 。

腾讯连游戏也涨不动了?出品虎嗅商业消费组作者黄青春题图视觉中国一份堪称滑铁卢的财报,腾讯疲态尽显。北京时间5月18日港股盘后,腾讯控股(0700。HK)发布2022年一季度业绩报告2022Q1实现营收1传统游戏社区的反NFT运动从何而来?在Web3工作,我听到传统游戏粉丝对NFTs和基于区块链的游戏有很多敌意。只要提到一个游戏工作室正在试验NFTs,就会引起社交媒体上玩家的批评。游戏粉丝以其对变化的热情和情绪反应而英媒美国急了,匆忙追赶中国超算领先地位据英国金融时报网站5月18日报道,美国即将凭借处理能力方面的大跃进跨入超级计算的新时代。处理能力的飞跃将对气候变化研究核武器试验等多个领域产生重大影响。报道称,但这一突破可能不会像猴痘病毒会不会变得更具传染性,进而威胁全球?美国专家会的多个欧美国家陆续出现的猴痘病毒疫情,正不断引起这些国家媒体的关注。其中,美国国立公共广播网(NPR)近日就刊登了一篇该网站在2017年时就猴痘问题对来自美国加州大学和美国陆军传染病美国英国选错5G新技术,会为华为打开5G大门吗?随着时间的推移,全球的发展潮流也是在不断变化,从中蒸汽到电气,也是跨越了几个世纪,但是,随着科技的进步,全球发展潮流的变化也似乎冲上了快车道,在通讯技术方面,转眼之间,就从曾经的2马斯克中国经济规模将达美国两三倍,美国必须停止内讧来源环球时报环球时报综合报道据美国福克斯新闻网17日报道,特斯拉首席执行官埃隆马斯克日前接受全方位(AllIn)播客主持人采访时表示,世界第二大经济体中国有朝一日将让美国的产值相形vivoS15系列发布,较上代有哪些升级?一性能S12天玑1100LPDDR4Xufs3。1S12Pro天玑1200处理器LPDDR4Xufs3。1S15骁龙870LPDDR4Xufs3。1S15Pro天玑8100独显芯片更时尚更全面?5月19日一起见证vivoS15系列亮相就在日前,vivo官方发布了一则消息,内容主要是说全新的vivoS15系列和更多的vivo新品将于5月19日正式登场,引起了广泛关注。那么这款新机能否继续捍卫S系列机圈颜值担当称号双芯性能,电影人像,vivoS15系列获四大官媒集体点赞vivo旗下主打年轻群体的vivoS系列于5月19日发布里程碑之作vivoS15系列。经过四年迭代升级,vivoS系列产品从拍照利器不断向全能型产品转型,为近3000万用户带来更全都说美团外卖月入过万,我怎么感觉我被忽悠了呢!你看这一天天的入职美团众包满打满算六个多月了,这一段时间以来出现了许多小插曲。钱挣得不多,有时候还很狼狈!从上年九月初就开始接触外卖行业了,从第一天的跑12单超时9单,到现在的成熟阶段,接单量力顶级风投a16z推出6亿美元基金专注于Web3和元宇宙游戏根据研究公司Naavik的一份报告,2021年游戏行业的收入超过3000亿美元。近日,知名风险投资公司AndreessenHorowitz(a16z)宣布推出6亿美元游戏基金GAM
年度最佳跑车之2021款保时捷718Cayman2021款保时捷718Cayman优点超凡的驾驶特性,两种变速箱都是完美,丰富的个性化选择。缺点机舱缺乏便利的存储点,四缸噪音比其他同行要贵。结论它可能是世界上最实惠的超级跑车。总年度最佳跑车之2021款雪佛兰Corvette2021款雪佛兰Corvette优点出色的性能与异国情调的汽车相媲美,舒适到愿意每天驾驶的精美座舱。缺点只有在全油门,有限的驾驶员辅助功能,不提供手动变速箱的情况下,排气才会令人兴年度最佳跑车之2021款保时捷718Boxster2021款保时捷718Boxster优点干脆的处理,急切的动力总成,自由风行。缺点精致的四缸噪音,缺乏存储空间,沉闷的座舱。结论尽管718Boxster有很多缺点,但令人兴奋的驾驶年度最佳轿车之2020款梅赛德斯AMGS63S652020款梅赛德斯AMGS63S65优点精心打造的座舱,快速加速,精致的操控性。缺点货运空间比竞争对手的轿车少,燃油效率比某些竞争对手低,底价比某些竞争对手高。结论S63和S65拥年度最佳跑车之2021款宝马M2优点喧闹而精致的发动机,满足驾驶特性,仍然提供自行换挡的变速器。缺点内饰缺乏M2价格的束缚,僵硬的行驶,更纤薄,动力更弱的M240i更物有所值。结论M2是出色的驾驶者的汽车,但对于年度最佳轿车之2020款梅赛德斯奔驰E级2020款梅赛德斯奔驰E级总览在某种程度上,E级轿车是梅赛德斯奔驰S级轿车的打折版本,这是一件好事。它具有与Benz旗舰轿车相同的抛光度和光泽度,并具有出色的内饰材料,安静的驾驶舱华为MateX2畅连APP有多香?全新的分享方式你会吗?2月22日晚间,华为新一代折叠旗舰手机MateX2正式发布,从设计到适配都达到了全新高度,刷新了我们对折叠屏手机的期待。搭载MateX2拖拽分享多应用分屏悬浮窗口等功能,畅连APP年度最佳轿跑车之2021款福特野马2021款福特野马优点所有型号的驾驶都乐趣无穷,座舱比Camaro的宽敞,性能出色。缺点座舱有一些低于标准的装饰件,可用的Recaro座椅过于激进,标准的四缸太柔和了。结论野马将形年度最佳轿车之2020款马自达32020款马自达3市场上最经典的紧凑型汽车体验之一。总览马3凭借全面的完善和先进的驾驶方式,是同类产品中最好的紧凑型汽车之一。马自达可作为掀背车或轿车提供,是本田思域和丰田卡罗拉等年度最佳轿车之2020款马自达62021款马自达6优点比竞争对手更经典,更出色的操控性,更安静的机舱。缺点涡轮发动机缺乏魅力,缺少环保型车型,为最贵的内饰级别预留了顶级选装件。结论马自达6是一款出色的家用轿车,因年度最佳SUV和跨界车之2021款宝马X32021宝马X3优点优美的行驶动力,强大的可选发动机,出众的燃油经济性。缺点微小的外后视镜无助于盲点,不完善的自动停止启动行为,过时的室内设计。结论X3是为渴望一些老式宝马驾驶技术