如何按嵌套参数

时间:2017-10-20 20:13:41

标签: javascript ruby each is-empty

我怎样才能改进这段代码,不要使用那么多_.each,并且不能总是验证对象的空白属性

  _.each(initial_obj, function(value, key){
    _.each(value, function(value2, key2){
      _.each(value2, function(value3, key3){
        _.isEmpty(new_obj[key3]) && (new_obj[key3] = {});
        _.isEmpty(new_obj[key3][key]) && (new_obj[key3][key] = []);
        new_obj[key3][key][key2] = value3;
      })
    })
  })


old_obj: {'a': {'en', 'es', 'pt'}, 'b': {'en', 'es', 'pt'}, 'c': {'en', 'es', 'pt'}})

  new_obj: {'en': ['a': [], 'b': [], 'c': []},
                          'es': {'a': [], 'b': [], 'c': []},
                          'pt': {'a': [], 'b': [], 'c': []}
                          })

2 个答案:

答案 0 :(得分:2)

使用Object#keysArray#reduce迭代对象的键。然后用Array#forEach迭代内部数组。对于数组中的每个字符串,assign key为空数组:

const obj = {'a': ['en', 'es', 'pt'], 'b': ['en', 'es', 'pt'], 'c': ['en', 'es', 'pt']};

const result = Object.keys(obj).reduce((r, key) => {
  obj[key].forEach((str) => r[str] = Object.assign(r[str] || {}, { [key]: [] }));
  
  return r;
}, {});

console.log(result);

答案 1 :(得分:0)

使用Ruby:

h = { a: ['en', 'es', 'pt'], b: ['en', 'es', 'pt'], c: ['en', 'es', 'pt'] }

values = h.first.last
  #=> ["en", "es", "pt"]
h.keys.map { |k| [k, values.map  { |v| [v,[]] }.to_h] }.to_h
  #=> {:a=>{"en"=>[], "es"=>[], "pt"=>[]},
  #    :b=>{"en"=>[], "es"=>[], "pt"=>[]}, 
  #    :c=>{"en"=>[], "es"=>[], "pt"=>[]}}