最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • JavaScript 数组操作必须熟练运用的8个方法

    正文概述 掘金(天行无忌)   2021-06-23   436

    【这是我参与更文挑战的第 23 天,活动详情查看: 更文挑战”】

    JavaScript 提供了大量不同的处理数组的方法,这里花几分钟时间介绍 8 个项目中可以用到的数组方法。

    1. Array.map()

    使用.map() 方法,可以创建一个基于原始数组的修订版数组。.map() 方法接受一个函数,该函数遍历数组中的所有项并进行相应的修改。

    当需要更新数组中的所有项并将其存储到一个新数组中时,.map() 方法就可以派上用场了。

    例如有一个文章列表的数组,如下:

    const articles = [
        {
            article_id: "6976209276364652558",
            title: "如何在 Vue 的计算属性中传递参数",
            views: 1258,
        },
        {
            article_id: "6976113133358153736",
            title: "Angular数据状态管理框架:NgRx/Store",
            views: 2258,
        },
        {
            article_id: "6975722363241365534",
            title: "Angular管道PIPE介绍",
            views: 1568,
        },
    ];
    

    现在基于上面文章列表数组,获取所有 title 组成的数组,如下:

    const arrayTitles = articles.map((item) => item.title);
    console.log(arrayTitles);
    

    输出的结果如下:

    [
      '如何在 Vue 的计算属性中传递参数',
      'Angular数据状态管理框架:NgRx/Store',
      'Angular管道PIPE介绍'
    ]
    

    当然,只要是数组都可以使用 .map() ,接下来就基于上面标题数组,增加作者信息,如下:

    const arrayTitlesWithAuthor = arrayTitles.map(
        (title) => `《${title}》作者:天行无忌`
    );
    console.log(arrayTitlesWithAuthor);
    

    输出结果如下:

    [
      '《如何在 Vue 的计算属性中传递参数》作者:天行无忌',
      '《Angular数据状态管理框架:NgRx/Store》作者:天行无忌',
      '《Angular管道PIPE介绍》作者:天行无忌'
    ]
    

    2. Array.filter()

    从方法名称可以很容易知道其用途,没错用于过滤数组元素。

    filter()方法根据特定条件获取数组中的元素,像 .map() 方法一样,它将返回一个新数组,并保持原始数组不变。

    基于上面的 articles 数组,分别获取 views 小于 2000 的和大于 2000 的文章列表:

    const lessArticles = articles.filter((item) => item.views < 2000);
    const muchArticles = articles.filter((item) => item.views > 2000);
    console.log(lessArticles);
    console.log("\r\n==========================================\r\n");
    console.log(muchArticles);
    

    输出的结果如下:

    [
      {
        article_id: '6976209276364652558',
        title: '如何在 Vue 的计算属性中传递参数',
        views: 1258
      },
      {
        article_id: '6975722363241365534',
        title: 'Angular管道PIPE介绍',
        views: 1568
      }
    ]
    
    ==========================================
    
    [
      {
        article_id: '6976113133358153736',
        title: 'Angular数据状态管理框架:NgRx/Store',
        views: 2258
      }
    ]
    

    3. Array.find()

    .find() 方法看起来很像前面介绍的.filter()方法。跟 .filter() 方法一样,将匹配的条件的元素返回,区别在于,.find() 将只返回与提供的条件匹配的第一个元素,不是数组。

    将上面的 .filter() 方法改为 .find(),如下:

    const lessArticle = articles.find((item) => item.views < 2000);
    const muchArticle = articles.find((item) => item.views > 2000);
    console.log(lessArticle);
    console.log("\r\n==========================================\r\n");
    console.log(muchArticle);
    

    输出结果如下:

    {
      article_id: '6976209276364652558',
      title: '如何在 Vue 的计算属性中传递参数',
      views: 1258
    }
    
    ==========================================
    
    {
      article_id: '6976113133358153736',
      title: 'Angular数据状态管理框架:NgRx/Store',
      views: 2258
    }
    

    4. Array.forEach()

    .forEach() 方法的工作方式很像常规的 for 循环,遍历一个数组并在每个元素上执行一个函数。 .forEach() 的第一个参数是回调函数,它包含循环数组的当前值和索引。

    如下:

    articles.forEach((item, index) => {
        console.log(`文章索引 ${index} 的标题为《${item.title}》`);
    });
    

    输出结果如下:

    文章索引 0 的标题为《如何在 Vue 的计算属性中传递参数》
    文章索引 1 的标题为《Angular数据状态管理框架:NgRx/Store》
    文章索引 2 的标题为《Angular管道PIPE介绍》
    

    5. for...of

    for...of 是es6推出的迭代器,号称最简洁,可以是用 breakcontinuereturn 终止循环。跟 .forEach() 不同的是,不提供数组索引。跟 for 语句相比代码少得多,更简洁。

    下面代码遍历输出数组,如下:

    for (const item of articles) {
        console.log(item);
    }
    

    6. Array.every()

    .every() 方法将检查数组中的每个元素是否都通过提供的条件,如果数组中的所有元素都通过条件,则将返回 true ,如果没有,将返回 false

    例如,检查 articles 数组所有的文章 views 都超过 1000,如下:

    const isMoreThan1000 = articles.every((item) => item.views > 1000);
    console.log(isMoreThan1000);  // true
    

    检查 articles 数组所有的文章 views 都超过 2000,如下:

    const isMoreThan2000 = articles.every((item) => item.views > 2000);
    console.log(isMoreThan2000); // false
    

    7. Array.some()

    .some() 方法和 .every() 方法类似,但验证的结果是相反的,如果数组中的所有元素只要有一个通过条件,则将返回 true ,如果所有的元素都不通过条件,将返回 false

    .some() 方法和 .every() 方法在文章《7 个你应该掌握的 JavaScript 编码技巧》中介绍了如何实现逻辑 andor

    例如,检查 articles 数组所有的文章 views 是否有 views 超过 2000 的文章,如下:

    const isMore2000 = articles.some((item) => item.views > 2000);
    console.log(isMore2000); // true
    

    检查 articles 数组所有的文章 是否有 views 超过 3000 的文章,如下:

    const isMore3000 = articles.some((item) => item.views > 3000);
    console.log(isMore3000);  // false
    

    8. Array.reduce()

    前面专门为此方法分享过一篇文章《javascript数组之includes、reduce》。

    .reduce() 方法接受一个回调函数作为其第一个参数,一个可选的初始值作为其第二个参数。如果没有提供初始值,则使用第一个数组元素作为值。回调函数提供一个累加器 accumulatorcurrentValue 参数,用于执行 reduce 计算。

    这里就简单举个例子,对 articles 数组的 views 进行累加求和:

    const sumViews = articles.reduce(
        (accumulator, current) => accumulator + current.views,
        0
    );
    console.log(sumViews); // 5084
    

    使用 .reduce() 方法可以用于展平一个数组,当然已经有很多方法可以做到这一点,这就是其中的方法之一。

    const flattened = [
        [0, 1],
        [2, 3],
        [4, 5],
    ].reduce((accumulator, current) => accumulator.concat(current), []);
    console.log(flattened); // [ 0, 1, 2, 3, 4, 5 ]
    

    总结

    JavaScript 提供了大量不同的处理数组的方法,本文介绍的8个在日常项目开发中使用频率比较高的数组处理方法,可以作为基础知识收藏。


    起源地下载网 » JavaScript 数组操作必须熟练运用的8个方法

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元