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

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

1.for循环

for循环是最基础常见的一种循环,圆括号中需要三个表达式,由分号分隔,最后面是一个花括号的块语句。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 < 10; i++) {

ajax.get(`/api/userName/${i}`).then(res => {

users[i] = res.name;

});

}

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

使用 let 块级作用域解决var users = {};

for (let i = 0; i < 10; i++) {

ajax.get(`/api/userName/${i}`).then(res => {

users[i] = res.name;

});

}

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

使用函数闭包作用域解决var users = {};

for (var i = 0; i < 10; i++) {

(function () {

var j = i;

ajax.get(`/api/user/${j}`).then(res => {

users[j] = res.name;

});

}());

}

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

使用函数参数作用域解决var users = {};

for (var i = 0; i < 10; i++) {

(function (value) {

ajax.get(`/api/user/${value}`).then(res => {

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))

输出结果

我们先使用对象字面量的方式定义量一个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); // true

console.log('city' in obj); // true

console.log('age' in obj); // true

console.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);

}

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;

}

});

php for of,JavaScript中 for、for in、for of、forEach的用法小结(附代码)相关推荐

  1. java乘法表_Java中四种9*9乘法表的实现方式(附代码)

    前言: 初学java,实现99乘法表是必学必会的内容. 需求 : 分别写出上下左右,对应四个角的乘法表. 思路: 可以先打印出*星星,形成一个直角三角形,然后再替换成乘法公式. 代码如下: publi ...

  2. python中get函数是什么意思_详解python中get函数的用法(附代码)_后端开发

    strncmp函数用法详解_后端开发 strncmp函数为字符串比较函数,其函数语法为"int strncmp ( const char * str1, const char * str2, ...

  3. python 加载动图_在浏览器中使用TensorFlow.js和Python构建机器学习模型(附代码)...

    大数据文摘授权转载自数据派THU 作者:MOHD SANAD ZAKI RIZVI 本文主要介绍了: TensorFlow.js (deeplearn.js)使我们能够在浏览器中构建机器学习和深度学习 ...

  4. 独家 | 在浏览器中使用TensorFlow.js和Python构建机器学习模型(附代码)

    作者:MOHD SANAD ZAKI RIZVI 翻译:吴金笛 校对:丁楠雅 本文约5500字,建议阅读15分钟. 本文首先介绍了TensorFlow.js的重要性及其组件,并介绍使用其在浏览器中构建 ...

  5. linux tensorflow demo_独家 | 在浏览器中使用TensorFlow.js和Python构建机器学习模型(附代码)...

    作者:MOHD SANAD ZAKI RIZVI 翻译:吴金笛 校对:丁楠雅 本文约5500字,建议阅读15分钟. 本文首先介绍了TensorFlow.js的重要性及其组件,并介绍使用其在浏览器中构建 ...

  6. Java中replace、replaceAll和replaceFirst函数的用法小结

    首先概述一下他们三个的用法: · replace(CharSequence target, CharSequence replacement) ,用replacement替换所有的target,两个参 ...

  7. pythonembed版是什么意思_HTML中embed什么意思?有哪些作用?(附代码)

    本篇文章主要给大家介绍html中embed 标签的定义及用法. 对于HTML学习者来说,标签的使用是至关重要的.那么对于新手来说,除了HTML常用标签需要学习熟练掌握外,还有一些不常见但也很重要的标签 ...

  8. return在php中用法,细致解读PHP中return用法(附代码)_后端开发

    在大部分编程言语中,return关键字能够将函数的实行效果返回,PHP中return的用法也迥然不同,对初学者来讲,控制PHP中return的用法也是进修PHP的一个入手下手. 起首,它的意义就是返回 ...

  9. Java实现float转换成int代码_Java中如何将float转换为long或int?(附代码)

    本篇文章给大家带来的内容是关于Java中如何将float转换为long或int?(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助. 在Java中,有三种方法可以将float转换 ...

  10. JavaScript中的逗号操作符(基础使用和拓展用法)

    一.逗号操作符的基础用法 逗号操作符可以用来在一条语句中执行多个操作,如下所示: 在一条语句中同时声明多个变量是逗号操作符最常用的场景.不过,也可以使用逗号操作符来辅助 赋值.在赋值时使用逗号操作符分 ...

最新文章

  1. 我用的 cordova 插件
  2. 浏览器地址栏传中文乱码
  3. BZOJ4285 : 使者
  4. 5、RH850 F1 定时器TAUJ功能和配置
  5. nema gps数据转换 matlab,NEMA-0183(GPRMC GPGGA)详细解释(GPS模块输出数据的解释)
  6. DOS简介及基本操作
  7. php微信消息通知,企业微信实现消息通知功能
  8. MDM数据分析设计方案
  9. 【houdini 基础】Ramp 参数
  10. Swin-Transformer 详解
  11. python表单验证wtf_正在验证wtfforms中的美国电话号码
  12. 实践材料1(感谢刘望的翻译)
  13. 如何利用eclipse创建一个java web项目?
  14. 什么是计算机图形学?(转自中国科学技术大学-刘利刚)
  15. go语言程序设计学习笔记-1
  16. 使用photoswipe展示图片
  17. google firebase入门之服务器集成
  18. Unity Shader - ddx/ddy偏导函数测试,实现:锐化、高度图、Flat shading应用、高度生成法线
  19. matlab数据整周期截断,凯塞窗四谱线插值FFT的电力谐波分析方法
  20. flex 的 三个参数:flex-grow、flex-shrink、flex-basis

热门文章

  1. gin 打linux环境包问题解决
  2. ansible 循环与条件判断when
  3. poj 3841 Double Queue (AVL树入门)
  4. 冲刺周期二--站立会议03
  5. iOS开发,导入CocoaPods常用的类库
  6. CSS如何让图片垂直并水平居中等比缩放?
  7. IE7 绝对定位z-index问题
  8. 配置主机间信任的一个简单办法
  9. ICLR'22 | 审稿结果统计速览
  10. 基于级联双向胶囊网络的鲁棒三元组知识抽取