Knockout.js 页面之间的导航Durandal do ko automapping而不是pass throw my model
我使用knockout和ajax调用用durandal编写了一个应用程序。 如果我直接访问详细信息页面,将参数传递给url,那么所有工作都会完成,但是如果我使用route.navigate从另一个页面访问页面,则Durandal使用从ajax请求到达的模型,而没有从我的模型传递,因此这会导致许多错误,因为我在模型中添加了属性和操作。 我试图添加canReuseForRoute返回false,但没有任何更改 你能帮帮我吗 多谢各位 壳牌jsKnockout.js 页面之间的导航Durandal do ko automapping而不是pass throw my model,knockout.js,durandal,Knockout.js,Durandal,我使用knockout和ajax调用用durandal编写了一个应用程序。 如果我直接访问详细信息页面,将参数传递给url,那么所有工作都会完成,但是如果我使用route.navigate从另一个页面访问页面,则Durandal使用从ajax请求到达的模型,而没有从我的模型传递,因此这会导致许多错误,因为我在模型中添加了属性和操作。 我试图添加canReuseForRoute返回false,但没有任何更改 你能帮帮我吗 多谢各位 壳牌js { route: 'movimento/:idLista
{ route: 'movimento/:idLista/:id', moduleId: 'viewmodels/movimento', title: 'Movimento', hash: '#movimento/:idLista/:id', nav:false }
大师js
self.editMovimento = function (item) {
router.navigate('movimento/'+ self.id + '/' + item.id());
}
详情js:
define(['plugins/router', 'plugins/dialog', 'knockout', 'komapping', 'moment'], function (router, dialog, ko, mapping, moment) {
MovimentoModel = function (data) {
var self = this;
mapping.fromJS(data, {}, self);
self.availableCategories = ko.observableArray();
self.availableTipiRipetizioni = ko.observableArray();
self.IsMovimento = ko.observable(true);
self.IsRipetizione = ko.observable(false);
self.IsLog = ko.observable(false);
console.log("Pass here only if I press F5 or I enter directly url in browser.");
}
return {
activate: function (idLista, id) {
var self = this;
var url = baseApiUrl + 'api/movimento/' + id;
return $.ajax({
type: "GET",
url: url,
headers: headers,
dataType: 'json'
}).done(function (data) {
self.movimento = new MovimentoModel(data);
self.movimento.idlista(idLista);
var idcategoria = self.movimento.idcategoria();
var idtiporipetizione = self.movimento.idtiporipetizione();
$.ajax({
type: "GET",
url: baseApiUrl + 'api/categoria?idlista=' + idLista,
headers: headers,
dataType: 'json'
}).done(function (data) {
$.each(data, function (index, obj) {
self.movimento.availableCategories.push(obj);
});
self.movimento.idcategoria(idcategoria);
});
});
}
你能提供一些代码来看看吗?是的,我添加了详细页面的javascript代码。