Я создал пример проблемы здесь:
http://jsfiddle.net/JustinN/qWeLT/1/
Мой настоящий код подключен к веб-методу ASP.NET, поэтому пример кода был настроен так, чтобы указывать на публичный веб-сервис для демонстрации.
По сути, у меня есть массив, к которому я привязываюсь, однако после вызова ajax в таблице не отображается обновленная информация. Я не уверен, что мне не хватает, сначала я подумал, что мне нужен плагин для картирования, поэтому я попробовал это, но до сих пор ничего не получаю.
Конечно, я не должен применять привязки каждый раз, когда меняются мои данные?
[EDIT]
JavaScript ниже:
var ViewModel = function () {
var self = this;
self.items = ko.observableArray([]);
self.refresh = function () {
$.ajax({
type: "POST",
url: "http://api.wipmania.com/json",
data: "{}",
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (data) {
ko.mapping.fromJS(data.d, self.items.address);
}
});
};
}
var viewModel = new ViewModel();
$(function () {
ko.applyBindings(viewModel);
viewModel.refresh();
});
HTML ниже:
<table data-bind="visible:items.length > 0">
<thead>
<tr>
<th>Country</th>
<th>Code</th>
</tr>
</thead>
<tbody data-bind="foreach: items">
<tr>
<td data-bind="text:country"></td>
<td data-bind="text:country_code"></td>
</tr>
</tbody>
</table>