次のようなノックアウト ビュー モデルがあります。
var TagViewModel = function (allPrincipals) {
var self = this;
self.name = ko.observable(tagName);
var principalMapping = {
create: function(options) {
return {
label: options.data.name,
key: options.data.type + '___|' + options.data.name,
icon: options.data.type == "User" ? "img/misc/user20.png" : "img/misc/group20.png"
};
},
key: function(data) {
return data.key;
}
};
self.allPrincipals = ko.mapping.fromJS(allPrincipals, principalMapping);
}
allPrincipals
次のようになります。
var allPrincipals = [{name: "Alex" type: "User"}, {name: "John", type: "User"}, {name: "Staff", type: "Group}]
したがって、viewModel が作成されると、次のようになります。
var vm = new TagViewModel(allPrincipals);
これはうまくいきます。
ただし、ビュー モデルでは、新しい項目を allPrincipals 観測可能配列 (マッピング プラグインによって作成) にプッシュできる必要があります。
これを行う最善の方法は何ですか?
たとえば、ビューモデルには次の関数があります。
self.addPrincipal = function(prinipal){
//allPrincipals.push(?)
}