使用 lodash 选择地图/深度选择
Pick map / deep pick with lodash
有没有办法写这种pick/map操作
edges = edges.map(([v1, v2]) => [vertices[v1], vertices[v2]]);
// example
const edges = [
[0, 1],
[1, 0]
];
const vertices = [
[0, 0],
[1, 1]
];
~~~>
[
[
[0, 0],
[1, 1]
],
[
[1, 1],
[0, 0]
]
]
更优雅,也许使用 lodash?
我目前最好的解决方案是:
function pickMap(edges, vertices) {
return ld.invokeMap(edges, "map", ld.propertyOf(vertices));
}
但也许我遗漏了一些更基本的程序。像
edges.map(([v1, v2]) => ld.pick(vertices, [v1, v2]))
接近,但它 returns 对象数组的键是错误的 (v1, v2) 而不是 (0, 1)。
您可以使用 _.at()
使用索引数组获取值数组:
const edges = [[0, 1],[1, 0]];
const vertices = [[0, 0],[1, 1]];
const result = edges.map(v => _.at(vertices, v));
console.log(JSON.stringify(result));
<script src="https://cdnjs.cloudflare.com/ajax/libs/lodash.js/4.17.20/lodash.min.js" integrity="sha512-90vH1Z83AJY9DmlWa8WkjkV79yfS2n2Oxhsi2dZbIv0nC4E6m5AbH8Nh156kkM7JePmqD6tcZsfad1ueoaovww==" crossorigin="anonymous"></script>
有没有办法写这种pick/map操作
edges = edges.map(([v1, v2]) => [vertices[v1], vertices[v2]]);
// example
const edges = [
[0, 1],
[1, 0]
];
const vertices = [
[0, 0],
[1, 1]
];
~~~>
[
[
[0, 0],
[1, 1]
],
[
[1, 1],
[0, 0]
]
]
更优雅,也许使用 lodash?
我目前最好的解决方案是:
function pickMap(edges, vertices) {
return ld.invokeMap(edges, "map", ld.propertyOf(vertices));
}
但也许我遗漏了一些更基本的程序。像
edges.map(([v1, v2]) => ld.pick(vertices, [v1, v2]))
接近,但它 returns 对象数组的键是错误的 (v1, v2) 而不是 (0, 1)。
您可以使用 _.at()
使用索引数组获取值数组:
const edges = [[0, 1],[1, 0]];
const vertices = [[0, 0],[1, 1]];
const result = edges.map(v => _.at(vertices, v));
console.log(JSON.stringify(result));
<script src="https://cdnjs.cloudflare.com/ajax/libs/lodash.js/4.17.20/lodash.min.js" integrity="sha512-90vH1Z83AJY9DmlWa8WkjkV79yfS2n2Oxhsi2dZbIv0nC4E6m5AbH8Nh156kkM7JePmqD6tcZsfad1ueoaovww==" crossorigin="anonymous"></script>