0

我得到了像

{"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
                );
            });
        }

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

4

4 回答 4

1

我相信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.
}
于 2012-05-23T15:29:18.437 回答
1
//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;
}

这行得通。

于 2012-05-23T15:32:06.467 回答
0

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

{
    success: function(data) {
        $.each(data, (function(dat) { return function(index, value) {
            $('#properties').append(
               value.ID + "," +
               value.Name + "," +
               dat.type + "," +
               dat.values
            );
        }; ) (data));
    }
};
于 2012-05-23T15:35:56.777 回答
0

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

于 2012-05-23T15:29:02.740 回答