zoukankan      html  css  js  c++  java
  • JavaScript数组(2)---遍历/迭代方法 8种

    最近工作中经常涉及到数据的处理,数组尤其常见,经常需要对其进行遍历、转换操作,网上的文章零零散散,不得已自己又找出红宝书来翻出来看,顺便记一笔,便于以后查询。

    • 数组常用的方法

    ECMAScript5为数组定义了8个迭代方法。每个方法都接受两个参数:要在每一项上运行的函数fn和(可选的)运行该函数的作用域对象——影响 `this` 的值。

    传入这些方法中的函数(fn)会接收3个参数:item 、index 、array; 如:

    array.forEach(function(item,index,array){
        //do your staff here;
    },this)

    根据使用方法的不同,这个函数执行后的返回值,可能会/不会影响方法中的返回值。

      这5个迭代方法作用及返回值概览如下(末尾补充另外3个):

    ECMAScript5 Array元素迭代方法
    方法名 方法作用  返回值
    every() 针对数组中每一项元素运行指定函数 Boolean:若每一项都返回true,返回true;
    filter() 针对数组中每一项元素运行指定函数, Array:   返回函数运行返回true的元素组成的新数组
    forEach() 针对数组中每一项元素运行指定函数 null:  无返回值
    map() 针对数组中每一项元素运行指定函数  Array:  返回函数运行后,得到到新新元素组成的新数组
    some() 针对数组中每一项元素运行指定函数 Boolean: 若有任意一项执行函数后返回true, 则返回true

    简单来说:

    every() 、some() 方法适合用于对数组元素进行条件判断;

    filter()  、map() 方法适合用于对数组进行条件筛选/再处理;

    forEach() 方法对不对数组本身做操作,仅仅对数组元素的二次应用;

    下面介绍下各个方法的使用栗子:

    先来假设一个场景,你拿到了公司的本月工资清单,假设你的工资为9000;公司员工工资组成的数组为salaries=[8500,12000,9900,9000],

    a. 想知道 你的工资是不是最低的;

    b.想知道 有没有人和你工资一样多;

    c.想知道  是不是所有人待遇都一样;

    d.想      把大家的工资都换成K为单位的数据 

     1 var a,b,c,d;
     2 var your=9000;
     3 var salaries=[8500,12000,9900,9000];
     4  a=salaries.some(function(item,index,array){
     5    return  item<9000
     6 });
     7 console.log(a);//true;恭喜你,还有人比你工资更低
     8 
     9 
    10 b=salaries.filter(function(item,index,array){
    11    return item== your;
    12 })
    13 console.log(b);//[9000] 呵呵,有人跟你待遇一样
    14 
    15 c=salaries.every(function(item,index,array){
    16    return item==your; 
    17 });
    18 console.log(c);//false .不是所有人都和你一样待遇哦
    19 
    20 d=salaries.map(function(item,index,array){
    21    return item/1000 
    22 });
    23 console.log(d);//[8.5,12,9.9,9]

      PS:补充三个遗漏的方法

    1.array.reduce(callback,[initalValue]):归并函数——对每个数组元素执行回调函数,返回最后一次调用结果值

        //此处回调函数有4个参数,其中第4个参数可选;即calback(accumulator,value,index,array,initalValue)

    2.Array.find(callback[,thisArg]):查找函数——返回第一个通过测试的元素

    3.Array.findIndex(callback[,Arg]):查找函数——返回第一个通过测试的元素的索引值

    看完这些是否觉得以后再也不需要for循环了,那么看看下面这个坑吧:

    [1,2,3].map(parseInt);//[1,NaN,NaN]
    
    
    
    
    //注意:
    //1.Array.map(iterm,index,array)
    //2.parseInt(value,base)
  • 相关阅读:
    程序员的一天
    美团点评云真机平台实践
    第5波:5本《自动化平台测试开发》+5本《软件自动化测试开发》又双叒叕来送书了...
    软件测试:管理篇
    软件测试:用例篇
    转载ASP.NET MVC 和ASP.NET Web Form简单区别
    转载ASP.NET 状态管理Application,Session,Cookie和ViewState用法
    转载 asp.net中ViewState的用法详解
    在ASP.NET中如何运行后台任务
    转载 .net中的dll.refresh文件和pdb文件
  • 原文地址:https://www.cnblogs.com/hbzyin/p/6493371.html
Copyright © 2011-2022 走看看