json 数组中的数组

Array inside json array

本文关键字:数组 json      更新时间:2023-09-26

我得到的结果像

{"ID":1022,"Type":"type1","Name":"name1","Values":[{"ID":3540,"Name":"1"},{"ID":3541,"Name":"2"},{"ID":3542,"Name":"cb"}]}

所以在成功时,我得到了这样的功能

   success: function(data) {
            $.each(data, function() {
                $('#properties').append(
                this.ID + "," +
                this.Name + "," +
                this.type + "," +
                    this.values
                );
            });
        }

但是"值"是另一个数组,那么如何显示呢?

//get the total length of values array.
this.Values.length;
for (  var i = 0 ; i < this.Values.length; i++ ){
 var resultId= this.Values[i].ID;
 var resultName = this.Values[i].Name;
}

这行得通。

我相信

this.Values[0].ID应该正确返回第一个元素的 ID。

您还可以遍历数组中的每个项目并以相同的方式访问它。

for (var i = 0; i < this.Values.length; i++) {
    alert(this.Values[i].ID); //Show an alert for each ID.
}

this.values[0].ID可能会起作用,但是,我不完全确定。不过,我想尝试一下并没有什么坏处。

我不太确定它在最内层函数中的值是什么,但它可能不是你想要的。为了在创建变量时将变量传递给函数,而不是在调用时传递变量,您应该将其包装为另一个函数,如下所示:

{
    success: function(data) {
        $.each(data, (function(dat) { return function(index, value) {
            $('#properties').append(
               value.ID + "," +
               value.Name + "," +
               dat.type + "," +
               dat.values
            );
        }; ) (data));
    }
};