Underscore.js-将键/值对的数组映射到Object-One行



我一直在浏览下划线文档,但似乎找不到进行以下转换的方法(或嵌套方法调用):

假设我有以下Javascript数组:

 [{ "name" : "sEcho", "value" : 1},{ "name" : "iColumns", "value" : 12}, ... ]

我需要将其转换为以下对象:

 {
      sEcho: 1,
      iColumns: 12,
      ...
 }

我使用undercore.js是有原因的,所以它必须是一行。

Sza答案的变体,使用_.object:的"对数组"签名

_.object(_.map(data, function(x){return [x.name, x.value]}))

由于没有人将其作为答案发布,我之所以发布它,是因为我认为它比Jan的答案更好。它更短,更干净,没有内联函数。

_.object(_.pluck(data, 'name'), _.pluck(data, 'value'));

这应该做到:

_.reduce(array, function(o, v){
    o[v.name] = v.value;
    return o;
}, {});

作为一句话(你在开玩笑,对吧?):

_.reduce(array,function(a,b){a[b.name]=b.value;return a},{});
var names = _.pluck(data, 'name');
var values = _.pluck(data, 'value');
var result = _.object(_.zip(names, values));
console.log(result);

假设您有以下JavaScript数组:

var list = [
    {
         name: "sEcho",
         value: 1
    },
    {
         name: "iColumns",
         value: 12
    },
    ...
];

您可以将其转换为您想要的格式,如下所示:

var table = _.reduce(list, function (table, item) {
    table[item.name] = item.value;
    return table;
}, {});

这不是一句话,但我不认为你的意思是一句话。是吗?

如果你真的想说一句话,这里有一句话:

var t = _.reduce(list, function (t, i) { return t[i.name] = i.value, t; }, {});

是的,其他人也给出了同样的答案。然而,这只是因为你的问题的答案很简单。

var a =  [{ "name" : "sEcho", "value" : 1},{ "name" : "iColumns", "value" : 12} ];
var o = {}; _.each(a, function(e) { o[e.name] = e.value; });
console.log(o);
// Object {sEcho: 1, iColumns: 12} 

使用reduce的完美位置我认为:

_.reduce(ary, function(memo, obj){ memo[obj["name"]] = obj["value"]; return memo }, {});

var arr = [{ "name" : "sEcho", "value" : 1},{ "name" : "iColumns", "value" : 12}]

ES6

_.mapObject( _.indexBy(arr, 'name'), (v) => v.value )

ES5

_.mapObject( _.indexBy(arr, 'name'), function (v) { return v.value; } )

这通过迭代两次

一种更好更简单的方法,这是我偶然发现的。

<script type="text/javascript">
  
        var obj = {
            Company: "GeeksforGeeks",
            Address: "Noida",
            Contact: "+91 9876543210",
            Email: "abc@gfg.com"
        }
        console.log(_.keys(obj));
    </script>

来源:https://www.geeksforgeeks.org/underscore-js-_-keys-function/

最新更新