ES6中常用函数

随手整理一下一些有用到的ES6函数

1. filter() 方法

filter() 方法创建一个新的数组,新数组中的元素是通过检查指定数组中符合条件的所有元素

注意:
filter() 不会对空数组进行检测
filter() 不会改变原始数组

//1. 根据条件过滤想要的数据
var  ages = [32, 33, 12, 40];
result = ages.filter(function(age){
      return age >= 18;
});
console.log(result);  //输出结果  [32, 33, 40]

//例2 根据关键字搜索
var  list = [
          { id: 1, name: '奔驰', ctime: new Date() },
          { id: 2, name: '宝马', ctime: new Date() }
];
var  search = (keywords,list) => { 
     return list.filter(item => {
          if (item.name.includes(keywords)) {
              return item;
          }
     });
};
//删除数组中ID的数
search('宝马',  list);
console.log(list);  //  [{ id: 2, name: '宝马', ctime: new Date() }]

2. includes() 方法

includes() 方法用来判断一个数组是否包含一个指定的值,如果是返回true,否则false。

语法:
参数两个,第一个参数是要查找的元素值 第二参数是可选的,是从该索引开始查找,默认为0。

// 例1
[1, 2, 3].includes(2);     // true
[1, 2, 3].includes(4);     // false
[1, 2, 3].includes(3, 3);  // false
[1, 2, 3].includes(3, -1); // true
[1, 2, NaN].includes(NaN); // true
// 例2
let  site = ['runoob', 'google', 'taobao'];
site.includes('runoob');  //true
site.includes('baidu');   //false

3. some() 方法

some() 方法用于检测数组中的元素是否满足指定条件(函数提供)
some() 方法会依次执行数组的每个元素

  • 如果有一个元素满足条件,则表达式返回true,剩余的元素不会在执行检测
  • 如果没有满足条件的元素,则返回false
    注意:some() 不会对空数组进行检测
    注意:some() 不会改变原始数组
var  list = [
          { id: 1, name: '奔驰', ctime: new Date() },
          { id: 2, name: '宝马', ctime: new Date() }
];
var  del = (id,list) => { 
     list.some((item, i) => {
          if (item.id == id) {
               this.list.splice(i, 1);
          }
     });
};
//删除数组中ID的数
del(1,  list);
console.log(list);  //  [{ id: 2, name: '宝马', ctime: new Date() }]

4.findIndex()

findIndex()方法返回(传入函数)符合条件的数组第一个元素位置
findIndex()方法为数组中的每个元素都调用一次函数执行:

  • 当数组中的元素在传入闭包函数返回true是,findIndex()返回符合条件的元素的索引位置,之后的值不会再调用执行函数
  • 如果没有符合条件的元素返回 -1
    注意: findIndex()对于空数组,函数是不会执行的。
    注意:findIndex()并没有改变数组的原始值
var  list = [
          { id: 1, name: '奔驰', ctime: new Date() },
          { id: 2, name: '宝马', ctime: new Date() }
];
var  del = (id,list) => { 
     var index = list.findIndex(item => {
        if(item.id == id) {
             return true;
        }
     });
     //删除数组中ID的数
     list.splice(index, 1);
};
del(1, list);
console.log(list);  //  [{ id: 2, name: '宝马', ctime: new Date() }]

find()

// 参考代码:
https://www.runoob.com/jsref/jsref-obj-array.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值