Javascript 使用来自ajax调用的数据更新可观测数组的每个元素的属性
我有一个ViewModel AppViewModel,它获取JSON数据来创建模型,其中一个属性totalSessions将使用ajax调用获取,模型AppViewModel返回一个可观察的数组,我的代码运行时没有任何错误,但视图似乎没有更新Javascript 使用来自ajax调用的数据更新可观测数组的每个元素的属性,javascript,jquery,ajax,knockout.js,ko.observablearray,Javascript,Jquery,Ajax,Knockout.js,Ko.observablearray,我有一个ViewModel AppViewModel,它获取JSON数据来创建模型,其中一个属性totalSessions将使用ajax调用获取,模型AppViewModel返回一个可观察的数组,我的代码运行时没有任何错误,但视图似乎没有更新 var jsonapparray = []; function AppViewModel(appsdata) { var self = this; var appsdata = $.parseJSON("["
var jsonapparray = [];
function AppViewModel(appsdata)
{
var self = this;
var appsdata = $.parseJSON("["+ JSON.stringify(appsdata["user_of"]) + "]");
var totalSessions = 0;
var i = 0;
for (var appkey in appsdata[0]) {
console.log(appsdata[0][appkey].name);
var elem = new Object();
elem._id = appsdata[0][appkey]._id;
elem.category = appsdata[0][appkey].category;
elem.country = appsdata[0][appkey].country;
elem.name = appsdata[0][appkey].name;
elem.key = appsdata[0][appkey].key;
elem.timezone = appsdata[0][appkey].timezone;
elem.totalsessions = 000;
jsonapparray.push(elem);
updateSessionsInfo(i,elem,jsonapparray);
i++;
}
self.AppCount = i;
self.Apps = ko.observableArray(jsonapparray);
function updateSessionsInfo(i,elem,jsonapparray)
{
$.ajax({
type:"GET",
url:Domain + "/o",
data:{
"api_key":readCookie("api_key"),
"app_id":elem._id,
"method":"sessions"
},
dataType:"jsonp",
async: false,
success:function (json) {
_sessionDb = json;
var totalSessions = _.pluck(_sessionDb,"t");
jsonapparray[j].totalsessions = totalSessions[0];
}
});
}
}
您应该更改:
jsonapparray[j].totalsessions = totalSessions[0];
致:
但这实际上没有帮助。更新数组中项目的属性不会触发更新。您应该使所有属性都可见,例如:
elem.totalsessions = ko.observable(0);
然后更新值,如下所示:
jsonapparray[i].totalsessions(totalsessions[0]);
jsonapparray[j].totalsessions中的j来自哪里?
jsonapparray[i].totalsessions(totalsessions[0]);