JQueryとKnockoutのバインドに問題があります!
問題がどこにあるのかわかりません!多分あなたの誰もがこのフィドルを見ることができます
これが、次のKnockoutViewModelに移動しようとする方法です。
masterViewModel.loginVM(null);
masterViewModel.startVM(new StartVM());
それが私のMasterViewModelです
var masterViewModel = {
loginVM: ko.observable(),
startVM: ko.observable(),
};
JQuery mobileを使用しない場合(ASP.NET MVC4プロジェクトにバインド)、正常に機能します
これは同じフィドルですが、jQueryは使用されていません:[fiddle] http://jsfiddle.net/B2A5f/)
ASP.NET MVC4でこれを試してみると、正しく機能しません。
<form action="" data-bind=" template:{ 'if': loginVM, data: loginVM }">
//SomeCode
</form>
<form action="" data-bind=" template:{ 'if': startVM, data: startVM}">
//Some Code
</form>
<script type="text/javascript">
var masterViewModel = {
loginVM: ko.observable(),
startVM: ko.observable(),
projektUnterbrechen: ko.observable(),
logout : ko.observable(),
projectStartVM: ko.observable()
};
var LoginVM = function () {
var self = this;
self.mandant = ko.observable();
self.user = ko.observable();
self.password = ko.observable();
self.showDetails = function () {
if ((self.user() == "Gregor") && (self.password() == "gregrech")) {
masterViewModel.loginVM(null);
masterViewModel.startVM(new StartVM());
}
else {
alert("Username oder Passwort falsch");
}
};
};
var StartVM = function () {
self = this;
//Um weiterzumachen muss man eingeloggt sein
self.favoriten = ko.observableArray([
{
projectName: "Favorit1"
},
{
projectName: "Favorit2"
},
{
projectName: "Favorit3"
}
]);
//Die zuletzt verwendeten Projekte
self.zuletzt = ko.observableArray([
{
lastProjName: "Zuletzt1"
},
{
lastProjName: "Zuletzt2"
},
{
lastProjName: "Zuletzt3"
}
]);
self.showStart = function (projectName, data, event) {
masterViewModel.projectStartVM(new ProjectStartVM(projectName));
masterViewModel.startVM(null);
};
};
masterViewModel.loginVM(new LoginVM());
$(document).on('pageinit', function () {
ko.applyBindings(masterViewModel);
});
</script>