javascript - 使用 lodash 递归收集属性值

标签 javascript recursion lodash

对于嵌套的复杂对象或数组,我想收集给定属性名称的所有值。示例:

var structure = {
    name: 'alpha',
    array: [
        { name: 'beta' },
        { name: 'gamma' }
    ],
    object: {
        name: 'delta',
        array: [
            { name: 'epsilon' }
        ]
    }
};

// expected result:  [ 'alpha', 'beta', 'gamma', 'delta', 'epsilon' ]

很明显如何使用纯 JS 实现这一点,但是:是否有使用 lodash 的任何优雅、简洁的方法?

[编辑] 下面的当前变体。欢迎更好的解决方案!

function getPropertyRecursive(obj, property) {
    var values = [];
    _.each(obj, function(value, key) {
        if (key === property) {
            values.push(value);
        } else if (_.isObject(value)) {
            values = values.concat(getPropertyRecursive(value, property));
        }
    });
    return values;
}

最佳答案

这可以通过以下 mixin 优雅地完成,它是 _.toPairs 的递归版本:

_.mixin({
    toPairsDeep: obj => _.flatMap(
        _.toPairs(obj), ([k, v]) =>
            _.isObjectLike(v) ? _.toPairsDeep(v) : [[k, v]])
});

然后得到你想要的结果:

result = _(structure)
    .toPairsDeep()
    .map(1)
    .value()

如果有 name 以外的标量属性,您必须将它们过滤掉:

result = _(structure)
    .toPairsDeep()
    .filter(([k, v]) => k === 'name')
    .map(1)
    .value()

关于javascript - 使用 lodash 递归收集属性值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39821320/

相关文章:

javascript - 检查标记是否位于当前可见区域中

javascript - 动态选择表单中的值

c++ - c++中不使用全局变量的递归函数中的加法次数

javascript - 如何使用Lodash根据一个键合并两个集合?

javascript - Lodash 从重复的对象键创建集合

javascript - 动态创建的元素都返回相同的索引

sql - 在 postgres 中,ORDER BY 似乎在递归 cte 中不起作用

java - 无法使用递归逐行遍历二维矩阵

javascript - 无限滚动去抖以避免过多调用

javascript - Selectize.js:使用默认值填充