Javascript
 Computer >> コンピューター >  >> プログラミング >> Javascript

JSON配列をJavaScriptで通常のjsonに変換する


次のようなキー/値ペアオブジェクトを持つJSON配列があるとします-

const arr = [{
   "key": "name",
   "value": "john"
},
{
   "key": "number",
   "value": "1234"
},
{
   "key": "price",
   "value": [{
      "item": [{
         "item": [{
            "key": "quantity",
            "value": "20"
         },
         {
            "key": "price",
            "value": "200"
         }]
      }]
   }]
}];

そのような配列を1つ取り込むJavaScript関数を作成する必要があります。

この関数は、この複雑な構造ではなく、データがキー値に対して単純にリストされる新しい配列を準備する必要があります。

したがって、上記の配列の場合、出力は次のようになります-

const output = {
   "name": "john",
   "number": "1234",
   "price": {
      "quantity": "20",
      "price": "200"
   }
};

このためのコードは-

になります
const arr = [{
   "key": "name",
   "value": "john"
},
{
   "key": "number",
   "value": "1234"
},
{
   "key": "price",
   "value": [{
      "item": [{
         "item": [{
            "key": "quantity",
            "value": "20"
         },
         {
            "key": "price",
            "value": "200"
         }]
      }]
   }]
}];
const simplify = (arr = []) => {
   const res = {};
   const recursiveEmbed = function(el){
      if ('item' in el) {
         el.item.forEach(recursiveEmbed, this);
         return;
      };
      if (Array.isArray(el.value)) {
         this[el.key] = {};
         el.value.forEach(recursiveEmbed, this[el.key]);
         return;
      };
      this[el.key] = el.value;
   };
   arr.forEach(recursiveEmbed, res);
   return res;
};
console.log(simplify(arr));

出力

そして、コンソールの出力は-

になります
{
   name: 'john',
   number: '1234',
   price: { quantity: '20', price: '200' }
}

  1. MySQL DATETIME値をJavaScriptでJSON形式に変換する方法は?

    変換するには、JSON.stringify()を使用します。以下は、JavaScriptでMySQLDATETIME値をJSON形式に変換するコードです- <script> var mySQLDateTime = new Date("Fri Sep 06 2019 22 −54 −48 "); var yearValue = mySQLDateTime.getFullYear(); var dateValue = mySQLDateTime.getDate(); var monthValue=mySQLDateTime.getMonth(

  2. JavaScript配列をJSONに変換する

    JavaScriptで配列をJSONに変換するためのコードは、次のとおりです- 例 <!DOCTYPE html> <html> <head> <style>    body {       font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;    } </style> </head> <body> <h1>Converting an ar