cómo empujar un elemento en una matriz con 15 objetos

votos
21
var array1 = [{
  candidateId: 57,
  firstName: Sumit,
  lastName: Kumar Gupta,
  displayName: Sumit1,
  locked: false,
  photoId: -1,
  resumeId: -1,
  experience:  6 Months,
  email: [email protected],
  mobile: +91.8100688592,
  prefferedLocation: [
    Bangalore
  ],
  currentEmployer: [

  ],
  skills: [{
    skillName: JAVA,
    level: advanced,
    candidateRating: 5,
    rating: 0
  }],
  viewed: true,
  nextStates: [{
    state: Approach
  }]]


var array2 = [image1]

Estoy recibiendo array2imágenes de otras pedido, por lo que asigné al array2. Ahora quería empujar o agregar esta array2en array1. Así que creé un objeto

'image'  
array2.push({'image':image1})

y trató de empujar

for(var i=0; i<array1.length;i++){
  array1[i].push(array2[i]);
}

pero no funcionó.

Publicado el 29/05/2018 a las 09:20
por usuario
En otros idiomas...                            


3 respuestas

votos
1

array1[i]['image'] = image1;o array1[i].image = image1; Es necesario agregar el objeto imagen para array1 valor utilizando descriptores de acceso.

MANIFESTACIÓN

var array1 = [{
 "candidateId": 57,
 "firstName": "Sumit",
 "lastName": "Kumar Gupta",
 "displayName": "Sumit1",
 "locked": false,
 "photoId": -1,
 "resumeId": -1,
 "experience": " 6 Months",
 "email": "[email protected]",
 "mobile": "+91.8100688592",
 "prefferedLocation": [
   "Bangalore"
 ],
 "currentEmployer": [

 ],
 "skills": [{
   "skillName": "JAVA",
   "level": "advanced",
   "candidateRating": "5",
   "rating": 0
 }],
 "viewed": true,
 "nextStates": [{
   "state": "Approach"
 }]
}]

for (var i = 0; i < array1.length; i++) {
 array1[i]['image'] = 'image1';
}
console.log(array1)

Respondida el 29/05/2018 a las 09:26
fuente por usuario

votos
0

Parece que está intentando acceder a la manera más índices en la matriz de dos que no están disponibles.

tratar:

for(var i=0; i<array1.length;i++){
  array1[i].push(array2[0]);
}
Respondida el 29/05/2018 a las 09:28
fuente por usuario

votos
1

Si usted está tratando de asignar dos matrices con la misma longitud, donde se van a combinar a continuación, un objeto desde cada posición del índice respectivo se puede mapsobre una de las matrices y el uso de sintaxis propagación de copia superficial y combinar los objetos. Este enfoque ayudará a prevenir los efectos secundarios, si bien la matriz de entrada tiene que ser dejado sin modificar.

El código sería el siguiente:

array1.map((obj, i) => ({...obj, image: array2[i]}));

Y la demo:

var array1 = [{
  "candidateId": 57,
  "firstName": "Sumit",
  "lastName": "Kumar Gupta",
  "displayName": "Sumit1",
  "locked": false,
  "photoId": -1,
  "resumeId": -1,
  "experience": " 6 Months",
  "email": "[email protected]",
  "mobile": "+91.8100688592",
  "prefferedLocation": [
    "Bangalore"
  ],
  "currentEmployer": [

  ],
  "skills": [{
    "skillName": "JAVA",
    "level": "advanced",
    "candidateRating": "5",
    "rating": 0
  }],
  "viewed": true,
  "nextStates": [{
    "state": "Approach"
  }]
}];


var array2 = ["image1"];

var combined = array1.map((obj, i) => ({...obj, image: array2[i]}));

console.log(combined);

Respondida el 29/05/2018 a las 09:56
fuente por usuario

Cookies help us deliver our services. By using our services, you agree to our use of cookies. Learn more