使用 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>