我在绑定 JQuery 和 Knockout 时遇到问题!
我不知道我的问题在哪里!也许你们中的任何人都可以看看这个小提琴
这就是我尝试进入下一个 Knockout ViewModel 的方式:
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>