知识回调

文章内容 文章链接
vue3 antd table表格增删改查(一)input输入框根据关键字搜索后台管理系统前端filter过滤 https://blog.csdn.net/XSL_HR/article/details/128072584?spm=1001.2014.3001.5501
vue3 antd table表格增删改查(二)input输入框根据关键字搜索【后台管理系统 请求后端接口 前后交互 https://blog.csdn.net/XSL_HR/article/details/128089801?spm=1001.2014.3001.5501

场景复现

在后台管理系统项目开发中,对于数组对象处理非常常见比如数组对象的排序数组对象的筛选数组对象的模糊查询。往期文章我们介绍了关于数组对象排序筛选内容,本期文章主要介绍判断数组对象是否含有某个值的方法


实现方式(6种)

利用循环遍历数组元素

function contains(arr, val) {
    for (var i = 0; i < arr.length; i++) {
        if (arr[i] === val) {
            return true;
        }
    }
    return false;
}
contains([1,2,3],3);//true

当然,也可以使用while语句

function contains(arr, val) {
    var i = arr.length;
    while (i--) {
       if (arr[i] === val){
           return true;
       }
    }
    return false;
}
contains([1,2,3,4],1);//true

利用somefilter方法

使用some方法更加简洁一旦找到元素迭代就会终止,从而避免了不必要的迭代周期(不过使用循环也能解决,但是增加了代码量)

示例代码

function contains(arr, val) {
    return arr.some(item => item === val);
}

这里可以直接使用箭头函数数据进行筛选,相比循环而言更加简洁

使用filter方法最为常见,filter本身为过滤的意思,一般在filter箭头函数添加筛选条件
注意array.filter(e=>e==x).length > 0等效于array.some(e=>e==x),但some更有效)

示例代码

function contains(arr, val) {
    return arr.filter((item)=> { return item == val }).length > 0;
}

利用array.indexOf方法

[1, 2, 3].indexOf(1);//0
["foo", "fly63", "baz"].indexOf("fly63");//1
[1, 2, 3].indexOf(4);//-1

注意:

利用array.includes方法

[1, 2, 3].includes(2); // true
[1, 2, 3].includes(4); // false

它还接受可选的第二个参数fromIndex

[1, 2, 3].includes(3, 3); // false
[1, 2, 3].includes(3, -1); // true

不像indexOf,它采用严格相等比较。这意味着您可以检测数组是否包含NaN

[1, 2, NaN].includes(NaN); // true

不同于indexOf,includes不会跳过缺失索引

new Array(5).includes(undefined); // true

利用array.find方法

find用于返回数组中满足条件第一个元素的值,如果没有,返回undefined

let numbers = [12, 5, 8, 130, 44];
let result = numbers.find(item => {
    return item > 8;
});
console.log(result);//12
//元素是对象
let items = [
    {id: 1, name: 'something'},
    {id: 2, name: 'anything'},
    {id: 3, name: 'nothing'},
];
let item = items.find(item => {
    return item.id == 3;
});
console.log(item) //Object { id: 3, name: "nothing" }

除了find我们可以使用array.indIndex。返回数组中满足条件第一个元素的索引下标), 如果没有找到,返回-1(和第三种方法indexOf类似)

利用set中has方法

function contains(arr, val) {
  return new Set(arr).has(val)
}
contains([1,2,3],2);//true

通过new set([])将数组转换成Set对象,set.prototype.has(value)判断该值是否存在于Set对象中,返回布尔值

延伸:除此之外,还可以利用它进行数组去重

let arr2 = new Set([1,1,2,3,4]) 
let arr3 = [...arr2] 
console.log(arr2,arr3) // {1,2,3,4} [1,2,3,4]

在这里插入图片描述

本期小结

本期文章详细介绍了六种方法,用于判断数组对象是否含有某个值。当然,在往期文章中,我们利用filter和indexOf对数据进行过简单增删改查,但是当查询的数据变成数组对象里的数组对象时,我们应该怎么解决呢?

下期文章将介绍vue antd table表格增删改查(三)(input输入框根据关键字模糊查询)

感兴趣小伙伴可以订阅专栏,方便后续了解学习~

觉得这篇文章有用的小伙伴可以点赞收藏关注哦~

在这里插入图片描述

原文地址:https://blog.csdn.net/XSL_HR/article/details/129787319

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_30748.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

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