映射对象数组中的值
Map values in array of objects
我有一个数组
const nodes = [
{ layer: '0' },
{ layer: 'input' },
{ layer: '0' },
{ layer: 'output' },
{ layer: '1' }
};
我想保留数组,但所有图层值都应该更改。
输入层应为1,所有数值应增加2,输出层应为新的最高数值加1。所有值应为数字而不是字符串。
因此新数组将是
const nodes = [
{ layer: 2 },
{ layer: 1 },
{ layer: 2 },
{ layer: 4 },
{ layer: 3 }
};
我用
完成了这个
const nodes = [
{ layer: '0' },
{ layer: 'input' },
{ layer: '0' },
{ layer: 'output' },
{ layer: '1' }
};
const output = Math.max.apply(Math, nodes.map((node) => Number.parseInt(node.layer, 10) || 0)) + 3;
nodes.map((node) => {
layer: neuron.layer === 'input' ? 1 : (neuron.layer === 'output' ? output : Number.parseInt(neuron.layer, 10) + 2)
})
好像可以,但是代码真的很难看。
不知道能不能做得比这更整洁
这可能是完成这项工作的一种方式;
var nodes = [
{ layer: '0' },
{ layer: 'input' },
{ layer: '0' },
{ layer: 'output' },
{ layer: '1' }
],
result = nodes.map(n => isNaN(+n.layer) ? n.layer === "input" ? {layer:1}
: {layer: n.layer}
: n.layer = {layer:+n.layer + 2});
result.find(o => o.layer === "output").layer = result.filter(f => !isNaN(f.layer))
.reduce((p,c) => p.layer > c.layer ? p : c)
.layer + 1;
console.log(result);
这个怎么样:
const nodes = [
{ layer: '0' },
{ layer: 'input' },
{ layer: '0' },
{ layer: 'output' },
{ layer: '1' }
];
nodes.filter( o => o.layer === 'output' )[0].layer =
1 + nodes.reduce( (max, node) => Math.max(max,
node.layer = +(node.layer === 'input') || +node.layer+2 || 0), 0);
console.log(nodes);
对于那些想知道 const
的人:常量性质只保护变量不被重新赋值;但是存储在数组中的对象可以自由改变。
我有一个数组
const nodes = [
{ layer: '0' },
{ layer: 'input' },
{ layer: '0' },
{ layer: 'output' },
{ layer: '1' }
};
我想保留数组,但所有图层值都应该更改。
输入层应为1,所有数值应增加2,输出层应为新的最高数值加1。所有值应为数字而不是字符串。
因此新数组将是
const nodes = [
{ layer: 2 },
{ layer: 1 },
{ layer: 2 },
{ layer: 4 },
{ layer: 3 }
};
我用
完成了这个const nodes = [
{ layer: '0' },
{ layer: 'input' },
{ layer: '0' },
{ layer: 'output' },
{ layer: '1' }
};
const output = Math.max.apply(Math, nodes.map((node) => Number.parseInt(node.layer, 10) || 0)) + 3;
nodes.map((node) => {
layer: neuron.layer === 'input' ? 1 : (neuron.layer === 'output' ? output : Number.parseInt(neuron.layer, 10) + 2)
})
好像可以,但是代码真的很难看。
不知道能不能做得比这更整洁
这可能是完成这项工作的一种方式;
var nodes = [
{ layer: '0' },
{ layer: 'input' },
{ layer: '0' },
{ layer: 'output' },
{ layer: '1' }
],
result = nodes.map(n => isNaN(+n.layer) ? n.layer === "input" ? {layer:1}
: {layer: n.layer}
: n.layer = {layer:+n.layer + 2});
result.find(o => o.layer === "output").layer = result.filter(f => !isNaN(f.layer))
.reduce((p,c) => p.layer > c.layer ? p : c)
.layer + 1;
console.log(result);
这个怎么样:
const nodes = [
{ layer: '0' },
{ layer: 'input' },
{ layer: '0' },
{ layer: 'output' },
{ layer: '1' }
];
nodes.filter( o => o.layer === 'output' )[0].layer =
1 + nodes.reduce( (max, node) => Math.max(max,
node.layer = +(node.layer === 'input') || +node.layer+2 || 0), 0);
console.log(nodes);
对于那些想知道 const
的人:常量性质只保护变量不被重新赋值;但是存储在数组中的对象可以自由改变。