У меня странная проблема с подключаемым модулем Knockout.
Если я заполняю наблюдаемый массив путем сопоставления, я не могу перебрать массив или получить его длину, даже если пользовательский интерфейс обновлен правильно, массив кажется пустым.
Вы можете найти работающий jsFiddle здесь: http://jsfiddle.net/VsbsC/
Это разметка HTML:
<p><input data-bind="click: load" type="button" value="Load" /></p>
<p><input data-bind="click: check" type="button" value="Check" /></p>
<table>
<tbody data-bind="foreach: items">
<tr>
<td data-bind="text: name"></td>
<td data-bind="text: value"></td>
</tr>
</tbody>
</table>
<p data-bind="text: total"></p>
Это код JavaScript:
var ViewModel = function () {
var self = this;
self.items = ko.observableArray();
self.load = function () {
self.items([
{ "name": "joey", "value": 1 },
{ "name": "anne", "value": 2 },
{ "name": "paul", "value": 3 },
{ "name": "mike", "value": 4 }
]);
};
self.check = function () {
alert(self.items().length);
};
self.total = ko.computed(function () {
var total = 0;
for (var i = 0; i < self.items().length; i++) {
total += self.items()[i].value;
}
return total;
});
};
var viewModel = new ViewModel();
ko.applyBindings(viewModel);
Когда я нажимаю кнопку Загрузить , записи и итоги отображаются правильно, а когда я нажимаю кнопку Проверка , я получаю правильный номер элемента.
Однако, если я изменю
self.items([
{ "name": "joey", "value": 1 },
{ "name": "anne", "value": 2 },
{ "name": "paul", "value": 3 },
{ "name": "mike", "value": 4 }
]);
до
self.items(ko.mapping.fromJS([
{ "name": "joey", "value": 1 },
{ "name": "anne", "value": 2 },
{ "name": "paul", "value": 3 },
{ "name": "mike", "value": 4 }
]));
пользовательский интерфейс по-прежнему отображается правильно, но итоговое значение показывает ноль, щелкнув Проверить , также возвращает ноль, а console.info
-ing self.items
- пустой массив.
Как это возможно? Я перечитывал учебники бесчисленное количество раз и не могу понять, что я делаю неправильно.
P.s. Мне нужно заполнить наблюдаемый массив через подключаемый модуль сопоставления, потому что на реальной странице значения поступают из запроса AJAX.