首页 > web前端 > js教程 > 如何过滤 JavaScript 对象中的属性?

如何过滤 JavaScript 对象中的属性?

Susan Sarandon
发布: 2024-11-11 20:46:03
原创
461 人浏览过

How Can I Filter Properties in a JavaScript Object?

对象的JavaScript filter() 方法

虽然Array 类型有filter() 方法,但Object 类型没有。本文旨在提供实现此类方法的解决方案。

自定义对象过滤器实现

一种方法涉及扩展 Object.prototype:

Object.prototype.filter = function(predicate) {
    var result = {};

    for (key in this) {
        if (this.hasOwnProperty(key) && !predicate(this[key])) {
            result[key] = this[key];
        }
    }

    return result;
};
登录后复制

替代解决方案

但是,扩展全局原型一般不鼓励。相反,请考虑以下替代方案:

1。使用Reduce和Object.keys

Object.filter = (obj, predicate) =>
    Object.keys(obj)
        .filter(key => predicate(obj[key]))
        .reduce((res, key) => (res[key] = obj[key], res), {});
登录后复制

2.映射和传播语法

Object.filter = (obj, predicate) =>
    Object.fromEntries(
        Object.entries(obj)
            .filter(([key, value]) => predicate(value))
            .map(([key, value]) => [key, value])
    );
登录后复制

3. Object.assign

const filter = (obj, predicate) =>
    Object.assign(
        {},
        ...Object.keys(obj)
            .filter(key => predicate(obj[key]))
            .map(key => ({[key]: obj[key]}))
    );
登录后复制

用法示例

var foo = { bar: "Yes", moo: undefined };

var filtered = Object.filter(foo, property => typeof property === "undefined");

console.log(filtered); // { moo: undefined }
登录后复制

以上是如何过滤 JavaScript 对象中的属性?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板