有人能帮助解释可能是根本故障我做的。 我需要能够有一个模型,可以组有自己的一套绑定的每个对象的列表。淘汰赛复杂的视图模型问题
小提琴显示了我什么,只有1块的例子做,但在最后,我想多块。
的Html
<script src="//ajax.googleapis.com/ajax/libs/jquery/1.8.0/jquery.min.js"
type="text/javascript"></script>
<div class="productblock">
<div class="product">
<input class="binding" data-bind="value: amount" type="text" value="1">
</div>
<div class="product">
<input class="binding" data-bind="value: amount" type="text" value="2">
</div>
<input class="discount" data-bind="value: discount" value="50">
</div>
</div>
<span id="res" data-bind="text: result">result here </span>
JS
function ResultViewModel() {
this.result = ko.computed(function() {
return 1;
});
}
function ProductViewModel(val) {
this.amount = ko.observable(val+1);
this.sum = function() {
return this.amount();
};
}
var products = [];
function ProductBlockViewModel(block) {
$.each($(block).find("div.product"), function (index, element) {
var product = new ProductViewModel($(element).find("input").val());
products.push(product);
ko.applyBindings(product);
});
this.discount = ko.observable(22);
}
var productBlocks = [];
$.each($("div.productblock"), function (index, element) {
console.log("a");
var productBlock = new ProductBlockViewModel(element);
productBlocks.push(productBlock);
ko.applyBindings(productBlock, element);
console.log("asdf");
});
ko.applyBindings(新ResultViewModel()); http://jsfiddle.net/Todilo/DGUKu/2/
如果您检查浏览器控制台,你会看到有要执行一个错误,停止你的代码。我仍然不明白你想达到什么目的。我相信有另一种方式来使代码更简单,重叠applyBindings不推荐 – phnkha
我需要能够映射 一个productblock 1产品 2产品 乙productblock 1产品 2产品 一些其他的东西 但我无法找到任何使用现有数据的例子 – Todilo
基本上它的嵌套我不知道。 – Todilo