es6 filter方法的参数有哪些

青灯夜游
发布: 2022-05-05 16:52:51
原创
3139人浏览过
filter方法接受两个参数:1、一个回调函数,不可省略,用于设置条件来过滤数组元素,并返回数组中满足条件的元素,语法“function(当前值,当前索引,数组对象){...}”;2、一个可选参数,可在回调函数中为其用this关键字的对象。

es6 filter方法的参数有哪些

本教程操作环境:windows7系统、ECMAScript 6版、Dell G3电脑。

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

简单来讲: filter() 方法可以返回数组中满足指定条件的元素。

 filter() 方法接受两个参数:

array.filter(callbackfn[, thisArg]);
登录后复制
  • callbackfn:回调函数,不可省略,用于设置条件来过滤数组元素,最多接受3个参数,语法:

    function(currentValue, index,arr)
    登录后复制
    • currentValue 必须。当前元素的值

    • index 可选。当前元素的索引值

    • arr 可选。当前元素属于的数组对象

    对于数组中的每个元素,filter 方法都会调用 callbackfn 函数一次。

  • thisArg:可选参数,可在 callbackfn 函数中为其用 this 关键字的对象。如果省略 thisArg,则 undefined 将用作 this 值。

    ClipDrop
    ClipDrop

    Stability.AI出品的图片处理系列工具(背景移除、图片放大、打光)

    ClipDrop 112
    查看详情 ClipDrop

返回值是一个包含回调函数为其返回 true 的所有值得新数组。如果回调函数为 array 的所有元素返回 false,则新数组的长度为 0。

对于数组中的每个元素,filter 方法都会调用 callbackfn 函数一次(采用升序索引顺序)。不为数组中缺少的元素调用该回调函数。回调函数的用法与 map 相同。

除了数组对象之外,filter 方法可由具有 length 属性,且具有已按数字编制索引的属性名的任何对象使用。

示例1:筛选出数组中的素数

var a = [31,33,35,37,39,41,43,45,57,49,51,53];
var a1 = a.filter(function(value, index, ar) {
    high = Math.floor(Math.sqrt(value)) + 1;
    for (var div = 2; div <= high; div ++) {
        if (value % div == 0) {
            return false;
        }
	}	
    return true;
}
);
console.log(a1);//31,37,41,43,53
</script>
登录后复制

1.png

示例2:过滤掉数组中在指定范围外的元素

var f = function (value) {
	if (typeof value !== 'number'){
		return false;
	} else {
		return value >= this.min && value <= this.max;
	}
}
var a = [6, 12, "15", 16, "the", -12];
var obj = {min : 10, max : 20};
var r = a.filter(f, obj);
console.log(r);  //12,16
登录后复制

2.png

【相关推荐:javascript视频教程web前端

以上就是es6 filter方法的参数有哪些的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号