Schleife durch JSON-Objekt-Liste
-
03-07-2019 - |
Frage
Ich kehre eine List <> von einem Webservice als Liste von JSON-Objekten. Ich versuche, ein for-Schleife zu verwenden, um durch die Liste zu durchlaufen und die Werte aus den Eigenschaften greifen. Dies ist ein Beispiel für die Rückkehr JSON:
{"d":[{"__type":"FluentWeb.DTO.EmployeeOrder",
"EmployeeName":"Janet Leverling",
"EmployeeTitle":"Sales Representative",
"RequiredDate":"\/Date(839224800000)\/",
"OrderedProducts":null}]}
Also ich versuche, den Inhalt mit so etwas wie diesem zu extrahieren:
function PrintResults(result) {
for (var i = 0; i < result.length; i++) {
alert(result.employeename);
}
Wie soll dies geschehen?
Lösung
hatte gleiches Problem heute, Ihr Thema hat mir geholfen, so hier geht Lösung;)
alert(result.d[0].EmployeeTitle);
Andere Tipps
Seien Sie vorsichtig, d
ist die Liste.
for (var i = 0; i < result.d.length; i++) {
alert(result.d[i].employeename);
}
Es ist nah! Versuchen Sie folgendes:
for (var prop in result) {
if (result.hasOwnProperty(prop)) {
alert(result[prop]);
}
}
Update:
Wenn Sie Ihr Ergebnis ist wirklich ein Array von einem Objekt, dann könnten Sie haben, dies zu tun:
for (var prop in result[0]) {
if (result[0].hasOwnProperty(prop)) {
alert(result[0][prop]);
}
}
Oder wenn Sie eine Schleife wollen durch jedes Ergebnis in dem Array, wenn es mehr, versuchen Sie:
for (var i = 0; i < results.length; i++) {
for (var prop in result[i]) {
if (result[i].hasOwnProperty(prop)) {
alert(result[i][prop]);
}
}
}
Hier ist sie:
success:
function(data) {
$.each(data, function(i, item){
alert("Mine is " + i + "|" + item.title + "|" + item.key);
});
}
Beispiel JSON Text:
{"title": "camp crowhouse",
"key": "agtnZW90YWdkZXYyMXIKCxIEUG9zdBgUDA"}
Da Sie jQuery verwenden, Sie könnten genauso gut das jede Methode verwenden ... Auch scheint es, wie alles, was ein Wert der Eigenschaft ‚d‘ ist in diesem Objekt JS [Notation].
$.each(result.d,function(i) {
// In case there are several values in the array 'd'
$.each(this,function(j) {
// Apparently doesn't work...
alert(this.EmployeeName);
// What about this?
alert(result.d[i][j]['EmployeeName']);
// Or this?
alert(result.d[i][j].EmployeeName);
});
});
Das sollte funktionieren. wenn nicht, dann vielleicht können Sie uns ein längeres Beispiel des JSON.
Edit: Wenn keines dieser Dinge funktionieren dann zu denken, ich fange es etwas falsch mit der Syntax Ihres JSON sein könnte.
var d = $.parseJSON(result.d);
for(var i =0;i<d.length;i++){
alert(d[i].EmployeeName);
}
Das funktioniert!
$(document).ready(function ()
{
$.ajax(
{
type: 'POST',
url: "/Home/MethodName",
success: function (data) {
//data is the string that the method returns in a json format, but in string
var jsonData = JSON.parse(data); //This converts the string to json
for (var i = 0; i < jsonData.length; i++) //The json object has lenght
{
var object = jsonData[i]; //You are in the current object
$('#olListId').append('<li class="someclass>' + object.Atributte + '</li>'); //now you access the property.
}
/* JSON EXAMPLE
[{ "Atributte": "value" },
{ "Atributte": "value" },
{ "Atributte": "value" }]
*/
}
});
});
Die Hauptsache über diese die Eigenschaft nutzt genau das gleiche wie das Attribut des JSON Schlüssel-Wert-Paares.
Ich habe den folgenden Aufruf:
$('#select_box_id').change(function() {
var action = $('#my_form').attr('action');
$.get(action,{},function(response){
$.each(response.result,function(i) {
alert("key is: " + i + ", val is: " + response.result[i]);
});
}, 'json');
});
Die Struktur von dem Server-Look kommt zurück wie:
{"result":{"1":"waterskiing","2":"canoeing","18":"windsurfing"}}