首页 > 解决方案 > 用 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]))

接近了,但它返回一个带有错误键 (v1, v2) 而不是 (0, 1) 的对象数组。

标签: javascriptarrayslodash

解决方案


您可以使用_.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>


推荐阅读