java遍历数组的各种方法_遍历数组的常用方法「建议收藏」

java遍历数组的各种方法_遍历数组的常用方法「建议收藏」1.最传统方法for循环1vararr=[“first”,”second”,”third”,”fourth”,3,5,8];2for(vari=0;i<arr.length;i++){3console.log(arr[i]);4}5//输出:6first7second8third9fourth10311512…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

1.最传统方法 for循环

1 var arr = [“first”,”second”,”third”,”fourth”,3,5,8];2 for(var i = 0; i < arr.length;i++){3 console.log(arr[i]);4 }5 //输出:

6 first7 second8 third9 fourth10 3

11 5

12 8

for… in

1 var arr = [“first”,”second”,’third’ ,”fourth”,3,5,8];2 for(var i inarr){3 console.log(arr[i] +’/’ +i);4 }5 //输出结果为:

6 first/0

7 second/1

8 third/2

9 fourth/3

10 3/4

11 5/5

12 8/6

for…of

1 var arr = [“first”,”second”,’third’ ,”fourth”,3,5,8];2 for(varitem of arr){3 console.log(item);4 }5 //输出结果:

6 first7 second8 third9 fourth10 3

11 5

12 8

虽然for… in 、 for… of 都能够变历数组,但是两者还是有很大区别的,先说结论:

两者的主要区别在于他们的迭代方式

推荐在循环对象属性的时候,使用for in,在遍历数组的时候推荐使用for of

for…in 循环出来的是key, for…of循环出来的是value

for…in 是ES5 标准,for …of 是ES6标准,兼容性可能存在些问题,请注意使用

for…of 不能遍历普通的对象,需要和Object.keys() 搭配使用

2.foreach方法:被传递给foreach的函数会在数组的每个元素上执行一次,元素作为参数传递给该函数

1 var arr = [“first”,”second”,”third”,”fourth”,3,5,8];2 //element 表示arr的单元项,index 表示arr单元项对应的索引值

3 arr.forEach(function(element,index){4 console.log(element + ‘/’ +index);5

6 })7 //输出结果:

8 first/0

9 second/1

10 third/2

11 fourth/3

12 3/4

13 5/5

14 8/6

注意:未赋值的值是不会在foreach循环迭代的,但是手动赋值为undefined的元素是会被列出的

1 var arr1 = [“first”,”second”, ,”fourth”,3,5,8];2 arr1.forEach(function(element,index){3 console.log(element + ‘/’ +index);4

5 })6 //输出结果

7 first/0

8 second/1

9 fourth/3

10 3/4

11 5/5

12 8/6

3.map 遍历数组,并通过callback对数组元素进行操作,并将所有操作结果放入数组中并返回该数组

1 var arr = [“first”,”second”,’third’ ,”fourth”];2 var arr2 = arr.map(function(item){3 returnitem.toUpperCase();4 })5 console.log(arr2);6 //输出:

7 [FIRST,SECOND,THIRD, FOURTH]

4.filter( )返回一个包含所有在回调函数上返回为true的元素新数组,回调函数在此担任的是过滤器的角色,当元素符和条件,过滤器就返回true,而filter则会返回所有符合过滤条件的元素

1 var arr = [“first”,”second”,’third’ ,”fourth”,3,5,8];2 var arr3 = arr.filter(function(item){3 if(typeof item == ‘number’){4 returnitem;5 }6 })7 console.log(arr3);8 //输出结果:

9 [3,5,8]

5. every() 当数组中的每一个元素在callback上被返回true时就返回true(注意:要求每一个单元项都返回true时才为true)

every()与filter()的区别是:后者会返回所有符合过滤条件的元素;前者会判断是不是数组中的所有元素都符合条件,并且返回的是布尔值

1 var arr = [“first”,”second”,’third’ ,”fourth”,3,5,8];2 var bol = arr.every(function(element){3 if(typeof element == ‘string’){4 returnelement;5 }6 })7 console.log(bol); //false

6.some()只要数组中有一项在callback上就返回true

every()与some()的区别是:前者要求所有元素都符合条件才返回true,后者要求只要有符合条件的就返回true

1 var arr = [“first”,”second”,’third’ ,”fourth”,3,5,8];2 var bol = arr.some(function(element){3 if(typeof element == ‘string’){4 returnelement;5 }6 })7 console.log(bol); //true

7.findindex() ES6数组新API,找到符合条件的索引并返回

1 var ages = [3, 10, 18, 20];2

3 functioncheckAdult(age) {4 return age >= 18;5 }

function(currentValue, index,arr)

参数currentValue:必需。当前元素

index:可选。当前元素的索引

arr:可选.当前元素所属的数组对象

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

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/192900.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Ewebeditor最新漏洞及漏洞大全

    Ewebeditor最新漏洞及漏洞大全

    2021年12月13日
    39
  • html下划线[通俗易懂]

    html下划线[通俗易懂]<spanstyle=”text-decoration:underline;”> 划重点</span>

    2022年6月4日
    26
  • 初学者:html中的表单详解(下面附有代码)

    初学者:html中的表单详解(下面附有代码)表单的理解与解释表单:采集不同类型的用户输入数据,发送给服务器,实现用户和服务器之间的数据交互。表单标签form声明数据采集的范围,只要是在form中的,都是要采集的数据。一个页面中可以有多个form标签,只能是并列关系,不能嵌套。只能是兄弟关系,,不能是父子关系。用户向服务器端发送数据时,一次只能提交一个表单中的数据。如果要提交多个表单就需要用js中的异步交互。表单元素method属性:提交表单时所用的http方法,默认为get方法。get方式:将数据作为url地址的一部分发送给服务器

    2022年8月11日
    6
  • java重构方式

    java重构方式这里只是简单例子,以动物方式,如何实现重构1、入口publicclassTestMain{@AutowiredprivateAnimalanimal;@Testpublicvo

    2022年7月2日
    23
  • Drupal开发学习入门指引[通俗易懂]

    Drupal开发学习入门指引[通俗易懂]我是云客,《云客drupal8源码分析》系列的作者,伴随着drupal8第一个正式版本发布到现在,该系列已经发布100期,超过60万字,作为中国投入精力最大、同时也是时间最早的第一批用户之一,云客觉得有义务帮助初学者准备好行囊,叮嘱好一路上的注意事项,之前也零星写过一些入门方面的资料,会在本文末给出链接(这些资料也很值得参考),本篇将为您全面整理需要的一切和规划学习步骤,这里假定您是一个刚刚学会p…

    2022年6月9日
    40
  • 激光导航和slam导航区别_激光导航和视觉导航的区别

    激光导航和slam导航区别_激光导航和视觉导航的区别激光SLAM基本原理基本原理

    2022年8月23日
    7

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号