我正在使用以下knockout observableArray和计算列代码,但是当我将值推送到observable数组时,UI(对于数据绑定计算)不会更新。请参阅我的jsFiddle示例。
是否有更好的方法将值推送到observableArray并让它们通过计算更新UI?提前谢谢。
HTML:
<html>
<head>
<script src="http://cloud.github.com/downloads/SteveSanderson/knockout/knockout-2.1.0.js" ></script>
</head>
<body>
<div data-bind="text: onString"></div>
<div id="test"></div>
</body>
</html>
JavaSript:
function MyData() {
var self = this;
self.currentOnOf = ko.observable(1);
self.available = ko.observableArray();
self.onString = ko.computed(function () {
return "On " + self.currentOnOf() + " of " + self.available ().length;}, self);
}
var data = new MyData();
$(document).ready(function () {
ko.applyBindings(data);
data.available().push(1);
data.available().push(2);
$("#test").html(data.available().length);
});
答案 0 :(得分:5)
当您推送到ko.observable数组时,您需要直接推送到它:
data.available.push(1);
data.available.push(2);