2010-10-10 6 views

Répondre

1

En boucle sur votre tableau d'objets (car c'est ce que c'est), et vérifiez l'attribut "id" de chaque objet.

var list = [ { "id": "10", "userName": "kuttan" }, { "id": "11", "userName": "kunjan" } ]; 

for (var i=0;i<list.length;i++) { 
    if (list[i].id == "10") { 
    alert(i); 
    }; 
}; 

Vous pourriez alors résumer ceci dans une fonction agréable.

function findIndexById(list, id) { 
    for (var i=0;i<list.length;i++) { 
    if (list[i].id == id) { 
     return i; 
    }; 
    }; 

    return -1; 
}; 

utiliser ensuite comme suit:

var list = [ { "id": "10", "userName": "kuttan" }, { "id": "11", "userName": "kunjan" } ]; 
var index = findIndexById(list, "10"); 

if (index !== -1) { 
    list[index].userName = "new username"; 
}; 
0

Vous boucle peut à travers le réseau et vérifier la propriété id de l'objet dans l'itération courante. Si c'est 10, attribuez le nouveau nom d'utilisateur à userName.

var json = [ { "id": "10", "userName": "kuttan" }, { "id": "11", "userName": "kunjan" } ], 
    len = json.length, 
    obj; 

while(len--) { 
    obj = json[len]; 
    if (obj.id == 10) { 
     obj.userName = 'foobar'; 
    } 
} 

console.log(json); // outputs [{id:"10", userName:"foobar"}, {id:"11", userName:"kunjan"}] 
Questions connexes