我有公司名單,當點擊每個公司需要顯示該公司的銷售人員。嵌套數組集合observable不工作在淘汰賽
我試過這個。下面是腳本,整個你可以找到http://jsfiddle.net/habdulha/gkqeD/29/
初始公司上市,但點擊該公司的銷售人員都沒有加載
<!-- language: lang-js -->
var rootViewModel = function(companies) {
this.companiesModel = ko.observableArray(companies);
}
var companyModel = function(salesPersonModel) {
CompanyId = ko.observable();
Name = ko.observable();
SalesPersonList = ko.observableArray(salesPersonModel);
LoadSalesPerson = function() {
var self = this;
var postData = {
companyId: this.CompanyId()
}
/// ajax to get the emp name based on company id
var data = $.ajax({
type: 'GET',
url: '/echo/json/',
data: postData,
success: function(result) {
/// result is based on companyid
var ajaxReply = {
"empName": "John",
"empName": "John 1"
};
self.SalesPersonList = ko.observableArray(ko.mapping.fromJS(ajaxReply)());
},
error: function(xhr, ajaxOptions, thrownError) {
alert(xhr.status);
alert(thrownError);
}
});
}
}
var salesModel = function() {
empName = ko.observable();
}
var myCompanyModelArray = new Array();
var mySalesModelArray = new Array();
mySalesModelArray[0] = new salesModel();
myCompanyModelArray[0] = new companyModel(mySalesModelArray);
var mainViewModel = new rootViewModel(myCompanyModelArray);
ko.applyBindings(mainViewModel);
$(document).ready(function() {
var data = $.ajax({
type: 'GET',
url: '/echo/json/',
//// get all the companies
success: function(data) {
var ajaxReply = {
{
"CompanyId ": "1",
"Name ": "Comp 1"
}, {
"CompanyId ": "2",
"Name ": "Comp 2"
}
};
residencyViewModel.yearGroupModel(ko.mapping.fromJS(ajaxReply)());
},
error: function(xhr, ajaxOptions, thrownError) {
alert(xhr.status);
alert(thrownError);
}
});
});
謝謝,工作。 – HashCoder 2012-04-25 08:43:35
@ColinE,我相信「RemoveAll()」應該是「removeAll()」。 – Simon 2014-03-31 12:59:34