JavaScript'te Nesne dizisini tek bir Nesneye nasıl dönüştürebilirim?


103

Bir dizi nesnem var:

[ 
  { key : '11', value : '1100', $$hashKey : '00X' },
  { key : '22', value : '2200', $$hashKey : '018' }
];

Bunu JavaScript ile aşağıdakine nasıl dönüştürebilirim?

{
  "11": "1000",
  "22": "2200"
}

4
[{key:"11", value:"1100"}, {key:"22", value:"2200"}].reduce(function(m,v){m[v.key] = v.value; return m;}, {})
david

Yanıtlar:


52

Muhtemelen bunun gibi bir şey arıyorsunuz:

// original
var arr = [ 
  {key : '11', value : '1100', $$hashKey : '00X' },
  {key : '22', value : '2200', $$hashKey : '018' }
];

//convert
var result = {};
for (var i = 0; i < arr.length; i++) {
  result[arr[i].key] = arr[i].value;
}

console.log(result);


2
FirstOne'ın modern bir yaklaşım için yanıtına göz atın .
Tibos

136

Tiny ES6 çözümü şöyle görünebilir:

var arr = [{key:"11", value:"1100"},{key:"22", value:"2200"}];
var object = arr.reduce(
  (obj, item) => Object.assign(obj, { [item.key]: item.value }), {});

console.log(object)

Ayrıca, nesne yayma kullanırsanız, şöyle görünebilir:

var object = arr.reduce((obj, item) => ({...obj, [item.key]: item.value}) ,{});

% 99 daha hızlı bir çözüm daha (jsperf üzerinde test edilmiştir):

var object = arr.reduce((obj, item) => (obj[item.key] = item.value, obj) ,{});

Burada virgül operatöründen yararlanırız, virgülden önce tüm ifadeleri değerlendirir ve son bir virgülden sonra (son virgülden sonra) döndürür. Bu yüzden kopyalamıyoruzobj , her seferinde yeni mülk atamak yerine .


3
Birini sevdim! var object = arr.reduce((obj, item) => (obj[item.key] = item.value, obj) ,{});
Sohail

bu bir satır daha mı hızlı yoksa geleneksel döngü mü?
Jeb50

2
@ Jeb50, geleneksel döngü en hızlısıdır, ancak virgül operatöründen fazla değildir. Object.assign / spread operatörü daha yavaş bir sıralamadır: jsperf.com/comma-operator-js
Josh Geller

1
İkinci nesneyi yaymayı unuttunuz({...obj, ...{[item.key]: item.value}}) ,{});
Julia

Teşekkürler, bunu bir nesneye sarmak aslında gerekli değil. Ben düzelttim.
Shevchenko Viktor

59

Bu görevi başarmak için işlevsel yaklaşımı seviyorum:

var arr = [{ key:"11", value:"1100" }, { key:"22", value:"2200" }];
var result = arr.reduce(function(obj,item){
  obj[item.key] = item.value; 
  return obj;
}, {});

Not: Son {}, objazaltma işlevi için başlangıç ​​değeridir, başlangıç ​​değerini sağlamazsanız, ilk arröğe kullanılacaktır (bu muhtemelen istenmeyen bir durumdur).

https://jsfiddle.net/GreQ/2xa078da/


2
ve anahtar dinamikse?
Stefano Saitta

1
Peki, verilen nesnenin / nesnenin hangi özelliğinin anahtar olarak ve hangisinin değer olarak kullanılmaması gerektiğini bilmelisiniz? Ancak wfirst prop'un her zaman anahtar ve ikinci değer olduğunu varsayarsak, şöyle bir geri çağırma işlevi kullanabiliriz: function (obj, item) {var keys = item.keys (); obj [öğe [anahtarlar [0]]] = öğe [anahtarlar [0]]; obj iad; }
GreQ

Yukarıdaki geri arama düzeltmesi: kod var obj = arr.reduce (işlev (obj, öğe) {var anahtarlar = Nesne.keys (öğe); obj [öğe [anahtarlar [0]]] = öğe [anahtarlar [1]]; dönüş obj;}, {});
GreQ

58

Bu yanıtı , JavaScript'te Nesneler dizisini tek bir Nesneye nasıl dönüştürebilirim bölümünde düzeltmeye çalışıyorum ? ,

bunu yapmalı:

var array = [
    {key:'k1',value:'v1'},
    {key:'k2',value:'v2'},
    {key:'k3',value:'v3'}
];
var mapped = array .map(item => ({ [item.key]: item.value }) );
var newObj = Object.assign({}, ...mapped );
console.log(newObj );


Tek satırlık:

var newObj = Object.assign({}, ...(array.map(item => ({ [item.key]: item.value }) )));

18

Object.fromEntries kullanarak :

const array = [
    { key: "key1", value: "value1" },
    { key: "key2", value: "value2" },
];

const obj = Object.fromEntries(array.map(item => [item.key, item.value]));

console.log(obj);


12

Bunu modern JavaScript kullanarak yapmanın temiz bir yolu aşağıdaki gibidir:

const array = [
  { name: "something", value: "something" },
  { name: "somethingElse", value: "something else" },
];

const newObject = Object.assign({}, ...array.map(item => ({ [item.name]: item.value })));

// >> { something: "something", somethingElse: "something else" }


5

Birçok yazarın önerdiği cevaplara dayanarak bir JsPref test senaryosu oluşturdum. https://jsperf.com/array2object82364

Aşağıda performansın ekran görüntüleri verilmiştir. Birkaç kez çalıştırdıktan sonra bile, krom sonucunun firefox ve edge ile zıt olduğunu görmek benim için biraz şok edici.

Kenar

Firefox

Krom


2

Underscore.js kullanarak :

var myArray = [
  Object { key="11", value="1100", $$hashKey="00X"},
  Object { key="22", value="2200", $$hashKey="018"}
];
var myObj = _.object(_.pluck(myArray, 'key'), _.pluck(myArray, 'value'));

2

Güncelleme: Dünya dönmeye devam etti. Bunun yerine işlevsel bir yaklaşım kullanın.

Hadi bakalım:

var arr = [{ key: "11", value: "1100" }, { key: "22", value: "2200" }];
var result = {};
for (var i=0, len=arr.length; i < len; i++) {
    result[arr[i].key] = arr[i].value;
}
console.log(result); // {11: "1000", 22: "2200"}

Bu, şaşırtıcı bir şekilde birinin 5 dakika önce gönderdiği yanıta benziyor
Alexander,

1
Çünkü bu sorunu bu şekilde çözersiniz. Örneğin adlandırma hakkında: arrayayrılmış bir anahtar kelimedir, bu nedenle insanlar arrbunun yerine kullanır. vb
pstadler

0

Yukarıdakileri bir dize olarak dinamik olarak nasıl kabul edeceğiniz ve onu bir nesneye nasıl enterpole edeceğiniz aşağıda açıklanmıştır:

var stringObject = '[Object { key="11", value="1100", $$hashKey="00X"}, Object { key="22", value="2200", $$hashKey="018"}]';

function interpolateStringObject(stringObject) {
  var jsObj = {};
  var processedObj = stringObject.split("[Object { ");
  processedObj = processedObj[1].split("},");
  $.each(processedObj, function (i, v) {
      jsObj[v.split("key=")[1].split(",")[0]] = v.split("value=")[1].split(",")[0].replace(/\"/g,'');
  });

  return jsObj
}

var t = interpolateStringObject(stringObject); //t is the object you want

http://jsfiddle.net/3QKmX/1/


0

// original
var arr = [{
    key: '11',
    value: '1100',
    $$hashKey: '00X'
  },
  {
    key: '22',
    value: '2200',
    $$hashKey: '018'
  }
];

// My solution
var obj = {};
for (let i = 0; i < arr.length; i++) {
  obj[arr[i].key] = arr[i].value;
}
console.log(obj)


Bu, soruyu cevaplasa da, bu cevabın sorunu çözmeye nasıl yardımcı olabileceğine dair bazı açıklamalar eklemek daha iyidir. Lütfen daha fazlasını öğrenmek için Nasıl iyi bir cevap yazabilirim bölümünü okuyun .
Roshana Pitigala

0

Bunun için mapKeys lodash işlevini kullanabilirsiniz. Sadece bir satır kod!

Lütfen bu eksiksiz kod örneğine bakın (kopyalayıp repl.it veya benzerine yapıştırın):

import _ from 'lodash';
// or commonjs:
// const _ = require('lodash');

let a = [{ id: 23, title: 'meat' }, { id: 45, title: 'fish' }, { id: 71, title: 'fruit' }]
let b = _.mapKeys(a, 'id');
console.log(b);
// b:
// { '23': { id: 23, title: 'meat' },
//   '45': { id: 45, title: 'fish' },
//   '71': { id: 71, title: 'fruit' } }

-3
        var obj = [
            {id: 1 , name : 'gaju' , class : 'kv'},
            {id: 2 , name : 'tushar' , class : 'Super'}
        ];

        function conv(obj,arg){
        var temp= {};
        var output= {}
        for(key in obj){
        temp[key] = obj[key];
        };

        var i=0;
        for(key in temp){
        var aa = {};
        var value = temp[key][arg];
        aa[value] = temp[i];
        //console.log(aa[value][arg] );
        output[aa[value][arg]]=  aa[value];
        i++;
        }

       console.log(output); 
        }

calling function 

    conv(obj,'class');
Sitemizi kullandığınızda şunları okuyup anladığınızı kabul etmiş olursunuz: Çerez Politikası ve Gizlilik Politikası.
Licensed under cc by-sa 3.0 with attribution required.