Knockout を使用して を操作する場合、長さを読み取るためにobservableArray
基になる配列 ( ) を取得する必要があります。基になる配列の長さを返さないmyArray()
理由がわかりません(代わりに 0 を返します)。myArray.length
これはバグですか、それとも単に見逃した理由がありますか?
JSFiddle: http://jsfiddle.net/jsm11482/LJVWE/
JS/モデル
var data = {
name: ko.observable("Test"),
items: ko.observableArray([
{ name: ko.observable("First Thing"), value: ko.observable(1) },
{ name: ko.observable("Second Thing"), value: ko.observable(2) },
{ name: ko.observable("Third Thing"), value: ko.observable(3) }
])
};
ko.applyBindings(data, document.getElementsByTagName("div")[0]);
HTML
<div>
<h1 data-bind="text: name"></h1>
<ul data-bind="foreach: items">
<li data-bind="text: value() + ': ' + name()"></li>
</ul>
<div>
<strong>data.items.length == </strong>
<!-- Expecting 3, get 0. -->
<span data-bind="text: items.length"></span>
</div>
<div>
<strong>data.items().length == </strong>
<!-- Expecting 3, get 3. -->
<span data-bind="text: items().length"></span>
</div>
</div>