4
我是新来淘汰赛,并希望有2个模型的网页上的2个链接。我希望链接上的点击事件切换显示哪个视图模型。我已经尝试了几种方法,并且有一个快捷方式https://jsfiddle.net/edgrttj3/7/但我无法使其工作。任何想法,我可能做错了什么?Knockout绑定2链接到不同的意见和swich modelview
<div id="content">
<a id="button1" href="#" >View 1</a>
<a id="button2" href="#" >View 2</a>
<hr />
<div data-bind="with: selectedView">
<div data-bind="template: { name: templateName, data: data }"></div>
</div>
<script id="oneTmpl" type="text/html">
<ul data-bind="foreach: items">
<li>
<span data-bind="text: id"></span>
<input data-bind="value: name" />
</li>
</ul>
</script>
<script id="twoTmpl" type="text/html">
First:
<input data-bind="value: firstName" />
Last:
<input data-bind="value: lastName" />
</script>
</div>
这里是JavaScript:
var View = function (title, templateName, data) {
this.title = title;
this.templateName = templateName;
this.data = data;
};
var subModelA = {
items: ko.observableArray([
{ id: 1, name: "one" },
{ id: 2, name: "two" },
{ id: 3, name: "three" }
])
};
var subModelB = {
firstName: ko.observable("Bob"),
lastName: ko.observable("Smith")
};
var viewModel = {
views: ko.observableArray([
new View("one", "oneTmpl", subModelA),
new View("two", "twoTmpl", subModelB)
]),
selectedView: ko.observable()
};
function setSelectedView(newview) {
alert(newview);
if (newview == "oneTmpl") {
viewModel.selectedView = viewModel.views[0];
} else {
viewModel.selectedView = viewModel.views[1];
}
};
ko.applyBindings(viewModel);
document.getElementById ("button1").addEventListener("click", setSelectedView('oneTmpl'), false);
document.getElementById ("button1").addEventListener("click", setSelectedView('twoTmpl'), false);
自举听起来不错,但最终我还是想在这里展开,并放置在不同的HTML文件的意见,了解如何能够在更大的视图集上进行淘汰,并通过链接更改显示的视图,并使用挖空装订设置模型数据。 – KH1229
@ KH1229我改变了解决方案:) – muhihsan
这很好!谢谢 – KH1229