come spingere un elemento in array con 15 oggetti

voti
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]

Io sono sempre array2le immagini da altra richiesta così ho assegnato in array2. Ora volevo spingere o aggiungere questo array2in array1. Così ho creato un oggetto

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

e provato spingendo

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

ma non ha funzionato.

È pubblicato 29/05/2018 alle 12:20
dall'utente
In altre lingue...                            


3 risposte

voti
1

array1[i]['image'] = image1;o array1[i].image = image1; È necessario aggiungere l'oggetto immagine al valore di array1 con accesso alle proprietà.

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"
 }]
}]

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

Risposto il 29/05/2018 a 12:26
fonte dall'utente

voti
0

Sembra che si sta tentando di accedere modo più indici in ordine di due che ci sono a disposizione.

provare:

for(var i=0; i<array1.length;i++){
  array1[i].push(array2[0]);
}
Risposto il 29/05/2018 a 12:28
fonte dall'utente

voti
1

Se si tenta di mappare due array con lunghezze uguali in cui un oggetto da ogni rispettiva posizione dell'indice deve essere unito allora si può mapsu una delle matrici e uso diffusione sintassi di copia superficiale e unire gli oggetti. Questo approccio aiuta a prevenire effetti collaterali se una matrice di ingresso deve essere lasciato non modificato.

Il codice sarebbe:

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

E l'una 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);

Risposto il 29/05/2018 a 12:56
fonte dall'utente

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