递归地迭代嵌套对象以更改所有出现的键值

时间:2019-01-17 03:59:49

标签: javascript angular recursion lodash iterated-function

有一个输入结构,其中的规则嵌套在其他规则中。在rules数组中,无论哪里有'data'属性,其值都必须更改为“ foo”

示例输入对象:

  1. {条件:“和”,规则:[{data:'123'}]}

  2. {条件:'或',规则:[{数据:'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;
 }

2 个答案:

答案 0 :(得分:2)

您提到的代码中存在潜在的错误。

  1. 在对iterateRules的递归调用中,您传递的是input而不是item
  2. 您还需要检查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。

相关问题