JavaScript循环遍历你会用哪些之小结篇


Posted in Javascript onSeptember 28, 2018

总结JavaScript中的循环遍历

定义一个数组和对象

const arr = ['a', 'b', 'c', 'd', 'e', 'f'];
const obj = {
  a: 1,
  b: 2,
  c: 3,
  d: 4
}

for()

经常用来遍历数组元素

遍历值为数组元素索引

for (let i = 0; len = arr.length, i < len; i++) {
  console.log(i);      // 0 1 2 3 4 5
  console.log(arr[i]);   // a b c d e f
}

forEach()

用来遍历数组元素

第一个参数为数组元素,第二个参数为数组元素索引,第三个参数为数组本身(可选)

没有返回值

arr.forEach((item, index) => {
  console.log(item);   // a b c d e f 
  console.log(index);  // 0 1 2 3 4 5
})

map()

用来遍历数组元素

第一个参数为数组元素,第二个参数为数组元素索引,第三个参数为数组本身(可选)

有返回值,返回一个新数组

every(),some(),filter(),reduce(),reduceRight()不再一一介绍,详细请看Js中Array方法有哪些?
let arrData = arr.map((item, index) => {
  console.log(item);   // a b c d e f 
  console.log(index);  // 0 1 2 3 4 5
  return item;
})
console.log(arrData);  // ["a", "b", "c", "d", "e", "f"]

for...in

可循环对象和数组,推荐用于循环对象

用于循环对象时

循环值为对象属性

for (let key in obj) {
  if (obj.hasOwnProperty(key)) {
    console.log(key);      // a b c d 属性
    console.log(obj[key]);  // 1 2 3 4 属性值
  }
}

用于遍历数组时

值为数组索引

for (let index in arr) {
  console.log(index);     // 0 1 2 3 4 5 数组索引
  console.log(arr[index]);  // a b c d e f 数组值
}

当我们给数组添加一个属性name

arr.name = '我是自定义的属性'

for (let index in arr) {
  console.log(index);      // 0 1 2 3 4 5 name (会遍历出我们自定义的属性)
  console.log(arr[index]);  // a b c d e f 我是自定义属性name
}

for...of

可循环对象和数组,推荐用于遍历数组

用于遍历数组时

遍历值为数组元素

for (let value of arr) {
  console.log(value);    // a b c d e f 数组值
}

用于循环对象时

须配合Object.keys()一起使用,直接用于循环对象会报错,不推荐使用for...of循环对象

循环值为对象属性

for (let value of Object.keys(obj)) {
  console.log(value);  // a b c d 对象属性
}

总结

用于遍历数组元素使用:for(),forEach(),map(),for...of
用于循环对象属性使用:for...in

以上所述是小编给大家介绍的JavaScript循环遍历你会用哪些小结篇,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
一个简单的JavaScript数据缓存系统实现代码
Oct 24 Javascript
js自动下载文件到本地的实现代码
Apr 28 Javascript
使用JS CSS去除IE链接虚线框的三种方法
Nov 14 Javascript
jquery通过select列表选择框对表格数据进行过滤示例
May 07 Javascript
JavaScript学习笔记之创建对象
Mar 25 Javascript
js实现页面a向页面b传参的方法
May 29 Javascript
Jquery 自定义事件实现发布/订阅的简单实例
Jun 12 Javascript
详解AngularJs中$resource和restfu服务端数据交互
Sep 21 Javascript
BootStrap 下拉菜单点击之后不会出现下拉菜单(下拉菜单不弹出)的解决方案
Dec 14 Javascript
在vue里面设置全局变量或数据的方法
Mar 09 Javascript
Vue自定义弹窗指令的实现代码
Aug 13 Javascript
webpack4.0 入门实践教程
Oct 08 Javascript
浅谈vue引用静态资源需要注意的事项
Sep 28 #Javascript
学习jQuery中的noConflict()用法
Sep 28 #jQuery
代码分析vue中如何配置less
Sep 28 #Javascript
使用JavaScript破解web
Sep 28 #Javascript
详解node字体压缩插件font-spider的用法
Sep 28 #Javascript
JS canvas绘制五子棋的棋盘
May 28 #Javascript
在vue中解决提示警告 for循环报错的方法
Sep 28 #Javascript
You might like
一次编写,随处运行
2006/10/09 PHP
Php做的端口嗅探器--可以指定网站和端口
2006/10/09 PHP
PHP操作文件方法问答
2007/03/16 PHP
php 中文字符入库或显示乱码问题的解决方法
2010/04/12 PHP
php empty函数判断mysql表单是否为空
2010/04/12 PHP
PHP手机号码归属地查询代码(API接口/mysql)
2012/09/04 PHP
php中用加号与用array_merge合并数组的区别深入分析
2013/06/03 PHP
php 强制下载文件实现代码
2013/10/28 PHP
javascript 跳转代码集合
2009/12/03 Javascript
神奇的7个jQuery 3D插件整理
2011/01/06 Javascript
Web跨浏览器进程通信(Web跨域)
2013/04/17 Javascript
Node.js中使用socket创建私聊和公聊聊天室
2015/11/19 Javascript
BootStrap Fileinput初始化时的一些参数
2016/12/30 Javascript
微信小程序实现YDUI的ScrollTab组件
2018/02/02 Javascript
Vue父组件调用子组件事件方法
2018/02/23 Javascript
Vue程序调试的方法
2019/06/17 Javascript
手把手教你 CKEDITOR 4 扩展插件制作
2019/06/18 Javascript
详解微信小程序图片地扯转base64解决方案
2019/08/18 Javascript
jQuery利用cookie 实现本地收藏功能(不重复无需多次命名)
2019/11/07 jQuery
微信小程序如何获取地址
2019/12/24 Javascript
Javascript模拟实现new原理解析
2020/03/03 Javascript
JavaScript中的全局属性与方法深入解析
2020/06/14 Javascript
[38:39]KG vs Mineski 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/16 DOTA
使用Django和Python创建Json response的方法
2018/03/26 Python
python使用thrift教程的方法示例
2019/03/21 Python
Python可变和不可变、类的私有属性实例分析
2019/05/31 Python
Python 实现数据结构-堆栈和队列的操作方法
2019/07/17 Python
使用Windows批处理和WMI设置Python的环境变量方法
2019/08/14 Python
Tensorflow中k.gradients()和tf.stop_gradient()用法说明
2020/06/10 Python
基于HTML5 Canvas 实现弹出框效果
2017/06/05 HTML / CSS
Evisu官方网站:日本牛仔品牌,时尚街头设计风格
2016/12/30 全球购物
英国最大的高品质珠宝和手表专家:Goldsmiths
2017/03/11 全球购物
Theflamel意大利:女士奢华服装、鞋子和配件
2020/01/11 全球购物
黄山导游词
2015/01/31 职场文书
2015年出纳个人工作总结
2015/04/02 职场文书
Debian11 Xfce终端光标的颜色怎么设置?
2022/08/14 数码科技