JavaScript中 for、for in、for of、forEach的用法小结(附代码)

本篇文章给大家带来的内容是关于JavaScript中 for、for in、for of、forEach的用法小结(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

在JavaScript中,我们经常需要去循环迭代方法操作数组对象等,常见等循环方法有 for、for in、for of、forEach等。

1.for循环

for循环是最基础常见的一种循环,圆括号中需要三个表达式,由分号分隔,最后面是一个花括号的块语句。

立即学习“Java免费学习笔记(深入)”;

for (var i = 0; i <10; i++){    if (i === 5) {        continue; //跳出当前循环    } else if (i === 8) {        break;    //结束循环    }    console.log(i);}

登录后复制

for循环中的语句

continue 语句用来跳出本次循环,但会继续执行后面的循环。  
break 语句用来结束循环,后面的循环不会再执行。  
return 并不能用来跳出for循环,return语句只能出现在函数体内,它会终止函数的执行,并返回一个指定的值。

使用for循环中遇到的问题

你可能会遇到在for循环使用一个异步操作,这也是一个很常见的面试题。在如下场景,你需要将一批id从0到9的用户名数据请求回来,并将id做为key,name为value塞到一个对象里,代码可能会是这样的

var users = {};for (var i = 0; i  {      users[i] = res.name;  });}

登录后复制

最后users对象的数据结果并非我们所想的那样,而是{10: ‘最后一个请求回来的用户名’}。这是因为异步请求的原因,由于事件队列机制,for循环会先全部执行完成,而异步请求会在后面的不定时间内完成,并且调用then方法被事件队列排在了后面,而此时在任意一个then方法内i变量已经在最后一次循环中被递增到等于10,在不停的调用then方法时,users对象key为10的value会被一直改写直到最后一个请求结束。

使用 let 块级作用域解决

var users = {};for (let i = 0; i  {      users[i] = res.name;  });}

登录后复制

将递增变量i使用let声明即可解决,let 语句声明一个块级作用域的本地变量,花括号里是一个块,每次循环都使用该块级作用域中的变量,可以看作每次循环的块都是相互隔离的,变量只会在该作用域内生效。

使用函数闭包作用域解决

var users = {};for (var i = 0; i  {        users[j] = res.name;     });  }());}

登录后复制

我们将异步方法包在一个立即执行函数里面,通过var j声明的变量去承接在该函数内i变量的值,由于立即执行函数形成了一个闭包作用域,变量j在每一个作用域内都是单独存在的。

使用函数参数作用域解决

var users = {};for (var i = 0; i  {        users[value] = res.name;     });  }(i));}

登录后复制

将变量i作为立即执行函数的参数传递进来,参数也具有各自的作用域,函数参数只在函数内起作用,是局部变量。

2.for in循环(es5)

for…in语句以任意顺序遍历一个对象的可枚举属性,遍历的顺序可能因浏览器实现方式有所不同。所遍历的内容可以是一个对象、数组、字符串、arguments等。使用Object.defineProperty方法可以为对象属性定义是否可以枚举。

枚举

在JavaScript中,对象的属性分为可枚举和不可枚举之分,它们是由属性的enumerable值决定的。可枚举性决定了这个属性能否被for…in查找遍历到。对象的propertyIsEnumerable方法可以判断此对象是否包含某个属性,并且返回这个属性是否可枚举。
Object, Array, Number等内置的方法和属性都是不可枚举的

const obj = {};Object.defineProperty(obj, 'city', {value: '北京', enumerable: false});const isEnumerable = obj.propertyIsEnumerable('city');console.log(obj);           // {city: "北京"}console.log(isEnumerable);  //false

登录后复制

for…in可以遍历可枚举但对象,包括不是它本身但存在于原型链上的属性。

const obj = {a:1, b:2, c:3};Object.defineProperty(obj, 'd', {value: 4, enumerable: false})obj.__proto__ = {name: 'ricky', age: '25'}console.log(obj)console.log('=====for in=======')for (var prop in obj) {  console.log(prop, obj[prop]);}console.log('=====Object.keys=======')console.log(Object.keys(obj))console.log('=====Object.getOwnPropertyNames=======')console.log(Object.getOwnPropertyNames(obj))console.log('=====Object.values=======')console.log(Object.values(obj))console.log('=====Object.entries=======')console.log(Object.entries(obj))

登录后复制

输出结果

3515977636-5bfb730c0be2b_articlex.png

我们先使用对象字面量的方式定义量一个obj,然后使用Object.defineProperty方法定义key为d的一个不可枚举属性,然后修改原型链__proto__,为其赋值了name, age两个属性。

for in遍历出除属性名为d以外的所有可枚举属性,包括其原型链上的属性

Object.keys方法会返回一个由对象的自身可枚举属性名(key)组成的数组,其原型链上的属性没有被包含

Object.getOwnPropertyNames方法会返回一个由对象的自身所有属性名(key)组成的数组,包括可枚举和不可枚举的属性

Object.values方法会返回一个由对象的自身可枚举属性的值(value)组成的数组

Object.entries方法会返回一个由对象的自身可枚举属性的键值对(key和value)组成的数组

for in会循环所有可枚举的属性,包括对象原型链上的属性,循环会输出循环对象的key,如果循环的是一个数组则会输出下标索引(index)。

in 运算符

in 运算符测试一个对象其自身和原型链中是否存在该属性。

const obj = {name: 'ricky'};Object.defineProperty(obj, 'city', {value: '北京', enumerable: false})obj.__proto__ = {age: '25'}console.log('name' in obj);   // trueconsole.log('city' in obj);   // trueconsole.log('age' in obj);    // trueconsole.log('sex' in obj);    // false

登录后复制

for of(es6) 循环可迭代对象

for of循环可迭代对象(包括 Array,Map,Set,String,TypedArray,类数组的对象(比如arguments对象、DOM NodeList 对象)、以及Generator生成器对象等)。

const array = [{a: 1}, {b: 2}, {c: 3}];array.name = 'ricky';console.log(array)console.log('=====for of=======')for (var prop of array) {  console.log(prop);}console.log('=====for in=======')for (var prop in array) {  console.log(prop);}

登录后复制

3814650713-5bfb730c15beb_articlex.png

for of 与 for in 不同处

与for in不同的是,for of不能循环普通对象({key: value})

for of不会将循环对象中自定义的属性内容循环出来

for in 是遍历键名(key或index),而for of是遍历键值(value)。

forEach、map 循环

forEach() 方法对数组的每个元素执行一次提供的函数,其中函数有三个参数,依次为:当前循环项的内容、当前循环的索引、循环的数组。

const array = ['a', 'b', 'c'];array.forEach(function(value, index, data) {    console.log(value, index, data);});// 输出// a  0  ["a", "b", "c"]// b  1  ["a", "b", "c"]// c  2  ["a", "b", "c"]

登录后复制

map() 方法会依次循环每一项,并且返回结果映射组成一个新的数组。

const array = [1, 2, 3];const newArray = array.map(function(value, index, data) {    return value * 2;});console.log(newArray);//输出 [2, 4, 6]

登录后复制

使用forEach、map不能中断循环,方法会将每项内容都执行完成才会结束循环。

使用every或 some 提前结束循环

every循环当返回false时循环即会结束, some方法在循环返回true时结束循环,利用这个特性使用every和some方法都可以跳出循环。

const arr = [1, 2, 3, 4, 5];arr.every(function(value){   console.log(value);   if(value === 3) {   //every 循环当返回false时结束循环       return false;   }   return true //every 循环需要返回true,没有返回值循环也会结束});arr.some(function(value){   console.log(value);   if(value === 3) {   //some 循环当返回true时结束循环       return true;   }});

登录后复制

以上就是JavaScript中 for、for in、for of、forEach的用法小结(附代码)的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2736291.html

(0)
上一篇 2025年3月8日 01:22:50
下一篇 2025年3月8日 01:22:59

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • Docker部署Node.js的详细过程

    本篇文章给大家带来的内容是关于php队列的实现代码介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 项目中会用到node做中间层,部署node则是用到了docker,在这里总结、记录下部署要点和步骤;关于docker的介…

    2025年3月8日
    200
  • Vue.js动态组件模板的详细介绍(代码示例)

    本篇文章给大家带来的内容是关于vue.js动态组件模板的详细介绍(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 组件并不总是具有相同的结构。有时需要管理许多不同的状态。异步执行此操作会很有帮助。 实例: 组件模…

    2025年3月8日
    200
  • JSONP跨域请求的理解(代码示例)

    本篇文章给大家带来的内容是关于jsonp跨域请求的理解(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 对于JSONP一直是知半解,今天利用周末整理了一下 维基百科的解释: JSONP (JSON with Pa…

    编程技术 2025年3月8日
    200
  • 基于vue下input实现图片上传,压缩,拼接以及旋转的代码详解

    本篇文章给大家带来的内容是关于php队列的实现代码介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 作为一名前端工作人员,相信大家在开发系统的时候,经常有遇到需要这么一种需求,就是需要为用户保存上传的图片,很多小白遇到这…

    2025年3月8日 编程技术
    200
  • Immutable.js源码之List 类型的详细解析(附示例)

    本篇文章给大家带来的内容是关于immutable.js源码之list 类型的详细解析(附示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 一、存储图解 我以下面这段代码为例子,画出这个List的存储结构: let my…

    2025年3月8日 编程技术
    200
  • react、redux和react-redux有什么关系?

    本篇文章给大家带来的内容是关于react、redux和react-redux有什么关系?,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 React 一些小型项目,只使用 React 完全够用了,数据管理使用props、st…

    编程技术 2025年3月8日
    200
  • JavaScript处理base64编码的代码示例

    本篇文章给大家带来的内容是关于javascript处理base64编码的代码示例,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 因为项目需求,需要处理base64编码,再次记录,便于之后调用 关于base64: base6…

    编程技术 2025年3月8日
    200
  • 面试:JavaScript中的setTimeout到底是什么?

    本篇文章给大家带来的内容是关于面试:JavaScript中的setTimeout到底是什么?,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 在刷笔试题的时候,经常会碰到setTimeout的问题,只知道这个是设置定时器;但…

    2025年3月8日 编程技术
    200
  • JavaScript运算符优先级的详细分析(附示例)

    本篇文章给大家带来的内容是关于JavaScript运算符优先级的详细分析(附示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 写了两年的JavaScript的我,原以为是不会在语法上阴沟里翻船的,可是事实上被打脸,最近…

    2025年3月8日
    200
  • es6中babel的用法介绍(代码示例)

    本篇文章给大家带来的内容是关于es6中babel的用法介绍(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 polyfill 我们都知道,js总是一直存在着兼容性问题,虽然其他语言也存在着兼容性问题,比如c++、…

    2025年3月8日 编程技术
    200

发表回复

登录后才能评论