web-dev-qa-db-fra.com

Comment mieux structurer un tableau de tableaux en JSON

Dans l'objet JSON suivant:

var employees = { "accounting" : [   // accounting is an array in employees.
                                { "firstName" : "John",  // First element
                                  "lastName"  : "Doe",
                                  "age"       : 23 },

                                { "firstName" : "Mary",  // Second Element
                                  "lastName"  : "Smith",
                                  "age"       : 32 }
                              ], // End "accounting" array.                                  
              "sales"       : [ // Sales is another array in employees.
                                { "firstName" : "Sally", // First Element
                                  "lastName"  : "Green",
                                  "age"       : 27 },

                                { "firstName" : "Jim",   // Second Element
                                  "lastName"  : "Galley",
                                  "age"       : 41 }
                              ] // End "sales" Array.
            } // End Employees

Comment puis-je restructurer l'objet pour pouvoir accéder à chaque prénom d'employé de la manière suivante:

employees[0].firstName
employees[1].firstName
// etc
9
Rigil

Cela nécessiterait une restructuration afin d'éliminer les propriétés "comptabilité/vente" et de transformer employees en un tableau d'objets.

Exemple: http://jsfiddle.net/hgMXw/

var employees = [
    {
    "dept": "accounting", // new property for this object
    "firstName": "John",
    // First element
    "lastName": "Doe",
    "age": 23
    },
    {
    "dept": "accounting", // new property for this object
    "firstName": "Mary",
    // Second Element
    "lastName": "Smith",
    "age": 32
    },
    {
    "dept": "sales", // new property for this object
    "firstName": "Sally",
    // Third Element
    "lastName": "Green",
    "age": 27
    },
    {
    "dept": "sales", // new property for this object
    "firstName": "Jim",
    // Fourth Element
    "lastName": "Galley",
    "age": 41
    }
] 
16
user113716

Vous ne pouvez pas faire pivoter ça comme ça. Soit vous déplacez le département en tant que clé dans l'objet employé ou vous devez y accéder comme employé.accounting [0] .firstName.

Si vous insistez pour accéder à l'employé en tant qu'employé [index], vous devez le restructurer pour:

var employees = [
  { "firstName" : "John", "lastName" : "Doe", "age" : 23, "department" : "accounting" },
  { "firstName" : "...", ..., "department" : "accounting" },
  ... and so on.
];

et introduisez une manière différente de filtrer par département.

peut-être créer une fonction qui parcourt le tableau d'employés, copier chaque élément correspondant au filtre dans un nouvel objet de tableau et le renvoyer.

function getAllEmployeesFilteredBy(filterName, filterValue, empArray)
{
  var result = [];
  for (var i=0; i < empArray.length; i++) {
    if (empArray[i][filterName] === filterValue)
      //by ref
      result[result.length] = empArray[i];

      //or if you prefer by value (different object altogether)
      //result[result.length] = { "firstName" : empArray[i].firstName, "lastName" : empArray[i].lastName, ... }
  }
  return result;
}
0
Jimmy Chandra

De jsFiddle

var employees = { "firstName" : "John",  // First element
                  "lastName"  : "Doe",
                  "age"       : 23 },

                { "firstName" : "Mary",  // Second Element
                  "lastName"  : "Smith",
                  "age"       : 32 }
                 ;
alert(employees);
0
fazo