有一个输入结构,其中的规则嵌套在其他规则中。在rules数组中,无论哪里有'data'属性,其值都必须更改为“ foo”
示例输入对象:
{条件:“和”,规则:[{data:'123'}]}
{条件:'或',规则:[{数据:'123'},{条件:'和',规则:[{数据:'123'},{数据:'456'}] }]
Am递归调用一个函数进行迭代,并且如果该项具有data属性,则更改其值
我的功能:
function iterateRules(input) {
input.rules.map(function(item) {
if(_.has(item, "rules")){
this.iterateRules(item); //bug-needs extra check like accepted answer
} else if(_.has(item, “data”)){
return item.data = “foo”;
}
}, this);
return input;
}
答案 0 :(得分:2)
您提到的代码中存在潜在的错误。
iterateRules
的递归调用中,您传递的是input
而不是item
input
是否具有rules
属性尝试一下-
function iterateRules(input) {
if(_.has(input, "rules")) {
input.rules.map(function(item) {
if(_.has(item, "rules")){
this.iterateRules(item);
} else if (_.has(item, "data")) {
return item.data = "foo";
}
}, this);
console.log(input);
}
}
答案 1 :(得分:1)
有一种递归方法可以实现这一点:
const input = {condition: "and", rules: [ { data: "123"}, {condition: "and", rules: [{data:"456"}, {condition: "and", rules: [{value: "456"}]} ] } ]}
function test (obj) {
if(!Object.keys(obj).includes('rules')) return;
obj.rules.forEach(x => x.data ? x.data = 'foo' : x);
return test(obj.rules.find(x => !Object.keys(x).includes('data')));
}
test(input)
console.log(input);
注意:此函数更改输入obj。