js过滤数组的filter用法(附与find的区别)

您所在的位置:网站首页 find和finds的区别和用法 js过滤数组的filter用法(附与find的区别)

js过滤数组的filter用法(附与find的区别)

2024-07-10 16:04:41| 来源: 网络整理| 查看: 265

一、使用背景

       相信很多前端开发者都有这么一个需求:拿到后端返回的某个字段值,但是这个值并不能直接展示在前端给用户看,我们需要转换格式,比如后端返回 “1”,我们要展示“男”,拿到 “2”,我们要展示“女”。这时就可以使用 filter 方法,注意本文讲的这个 filter 是数组的一个方法,而不是组件中的filters:{},开发者可自行在组件 filters:{} 中加入筛选函数去转换格式。

二、filter使用方法与注意事项

直接上代码会更直观:

        如图所示,countryOptions 是要进行筛选的一个数组,它有一个 filter 方法,item 则是countryOptions 里的每一个子项,filter 会遍历这个数组,将满足 item.value === "C" 的子项拿出来放在 filters1 数组中,直到筛选出所有满足条件的子项才结束,因此它返回的一定是个数组,哪怕只有一个子项满足条件。

注意点:

1、如果参数只有一个,括号可加可不加,但是参数超过 1 个时必须使用括号;

2、如果执行体加了 {},那么必须要有 return 关键字,否则筛选出的数组永远为空;

3、除了箭头函数,也可以用常规的普通函数去筛选条件,结果是一样的;

4、不论哪种方式去进行筛选,被筛选的原数组是不会被改变的;

5、如果未筛选出指定条件的数组,则返回空数组 [ ],所以其结果永远不会为 undefined 或者 null(该条注意点为最近新增,未体现在上面的代码中,开发者们可自行去验证);

6、如果 countryOptions 是作为下拉框的选项,那么它里面每个对象的 value 必须唯一,图中只是为了举例,不用于实际项目。

三、filter与find的区别

还是直接上代码:

       从上图可以总结出 filter 与 find 的区别与共同点:

1、filter 遍历数组后会把所有符合条件的子项筛选出来,而 find 按顺序遍历数组后只会把符合条件的第一个子项筛选出来,然后就停止遍历;

2、因为 filter 是筛选出所有满足条件的子项,所以返回的结果一定是个数组对象,哪怕只筛选出了一项(见 filters3);而 find 因为只返回一项,故返回的结果是一个非数组的对象(见 filters4);

3、当未筛选出满足指定条件的对象时,filter 会返回空数组 [ ],其结果永远不为 undefined 或者null,但是 find 则一定是返回 undefined,这一点在做对象的判断时尤其要注意;

4、共同点就是被筛选的原数组都不会被它们所改变(见第25行代码的输出)。



【本文地址】

公司简介

联系我们

今日新闻


点击排行

实验室常用的仪器、试剂和
说到实验室常用到的东西,主要就分为仪器、试剂和耗
不用再找了,全球10大实验
01、赛默飞世尔科技(热电)Thermo Fisher Scientif
三代水柜的量产巅峰T-72坦
作者:寞寒最近,西边闹腾挺大,本来小寞以为忙完这
通风柜跟实验室通风系统有
说到通风柜跟实验室通风,不少人都纠结二者到底是不
集消毒杀菌、烘干收纳为一
厨房是家里细菌较多的地方,潮湿的环境、没有完全密
实验室设备之全钢实验台如
全钢实验台是实验室家具中较为重要的家具之一,很多

推荐新闻


图片新闻

实验室药品柜的特性有哪些
实验室药品柜是实验室家具的重要组成部分之一,主要
小学科学实验中有哪些教学
计算机 计算器 一般 打孔器 打气筒 仪器车 显微镜
实验室各种仪器原理动图讲
1.紫外分光光谱UV分析原理:吸收紫外光能量,引起分
高中化学常见仪器及实验装
1、可加热仪器:2、计量仪器:(1)仪器A的名称:量
微生物操作主要设备和器具
今天盘点一下微生物操作主要设备和器具,别嫌我啰嗦
浅谈通风柜使用基本常识
 众所周知,通风柜功能中最主要的就是排气功能。在

专题文章

    CopyRight 2018-2019 实验室设备网 版权所有 win10的实时保护怎么永久关闭