Javascript 如何按嵌套参数分组
我如何才能改进这段代码,使其不使用那么多的u。每个和by并不总是验证其属性的对象空性Javascript 如何按嵌套参数分组,javascript,ruby,each,is-empty,Javascript,Ruby,Each,Is Empty,我如何才能改进这段代码,使其不使用那么多的u。每个和by并不总是验证其属性的对象空性 _.each(initial_obj, function(value, key){ _.each(value, function(value2, key2){ _.each(value2, function(value3, key3){ _.isEmpty(new_obj[key3]) && (new_obj[key3] = {}); _.
_.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': []}
})
使用和迭代对象的键。然后迭代内部数组,使用。对于数组中的每个字符串,使用空数组的
键
:
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]:[]);
返回r;
}, {});
控制台日志(结果)使用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"=>[]}}
使用新的有效数据打开新问题。;]