【发布时间】:2016-05-22 11:16:29
【问题描述】:
我的 Javascript 代码中有一个数据对象,描述如下:
//Data Object that represents products
function Product(n, p, t, d) {
this.name = ko.observable(n);
this.price = ko.observable(p);
tags = typeof (t) !== 'undefined' ? t : [];
this.tags = ko.observableArray(tags);
discount = typeof (d) !== 'undefined' ? d : 0;
this.discount = ko.observable(discount);
this.formattedDiscount = ko.computed(function ()
{ return (this.discount() * 100) + "%"; }
,this);
}
然后,我有一个 AJAX 调用来检索 JSON 格式的数据
$(document).ready(function () {
$.ajax({
type: "POST",
url: "ShoppingCartExampleExample.aspx/SendData",
data: "{}",
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (msg) {
alert(msg.d);
}
});
});
AJAX 调用正常,结果如下:
[
{"Discount":0,
"Name":"Chocolate",
"Price":"7.99"
"tags": ["Mars","Snickers"]
},
{"Discount":0.05,
"Name":"Beer",
"Price":"3.99"
"tags": ["Large","Extra"]
}
]
如何将从 AJAX 调用接收到的对象列表映射到我的数据对象? 我想将此列表映射到可观察数组,并将标签数组映射到可观察数组,因为我有一个 foreach 绑定,它填充 HTML 表以显示产品和标签。
谢谢
【问题讨论】:
标签: javascript json ajax knockout.js