【发布时间】:2016-09-27 04:13:33
【问题描述】:
我正在使用 JS Knockout 来显示来自 Four Square API 的搜索结果。 我的 Javascript 代码中有这个视图模型
var ViewModel = function(){
var self = this;
// Foursquare API Call :
this.foursquareURL = 'https://api.foursquare.com/v2/venues/search?ll=37.8,-122.4&query=croissant&client_id=CLIENT_ID&client_secret=CLIENT_SECRET';
this.fs_ApiCall = function()
{
$.getJSON(foursquareURL, function(data){
$foursquareElem.text('Get a croissant');
var venues = data.response.venues;
self.venueList = ko.observableArray([]);
for (var i=0; i<venues.length; i++){
self.venueList.push ({
name: venues[i].name,
lat: venues[i].location.lat,
lng: venues[i].location.lng
});
}
}).error(function() {
$foursquareElem.text( "No data available" );
});
};
};
ko.applyBindings(new ViewModel());
这就是我在 HTML 文档中应用绑定的方式
<div id="foursquare-venues">
<ul data-bind= "foreach:venueList">
<li id="li-name" data-bind = "text:name">
</li>
</ul>
未捕获的 ReferenceError: 无法处理绑定“foreach: function (){return avenueList }” 消息:未定义场所列表
我不确定我是否使用了正确的方式在 API 中推送 API 响应,但错误消息似乎表明该数组甚至没有定义 (?) 我不确定这里出了什么问题。
【问题讨论】: