使用Knockout.js的简单Flickr应用程序不起作用(JSBin准备的)
simple Flickr application with Knockout.js doesn't work (JSBin prepared)
现在我正在编写一个简单的应用程序,它从Flickr获取五张照片并将标题显示为列表。一开始我尝试了@current_photos
,这工作得很好,但是当我使用Knockout.js(@currentPhotos
)时,这不起作用。
root = exports ? this
class root.Flickr
constructor: ->
@photos = []
$.getJSON(
'http://www.flickr.com/services/rest/?jsoncallback=?'
format : 'json'
method : 'flickr.photos.search'
api_key : '7965a8bc5a2a88908e8321f3f56c80ea'
user_id : '29242822@N00'
per_page : 5
).done((data) =>
$.each data.photos.photo, (i, item) =>
@photos.push item
)
root = exports ? this
class root.PhotoListViewModel
index = null
currentPhotos = []
constructor: ->
flickr = new Flickr
# @current_photos = flickr.photos ###### WORKS GOOD
flickr.photos = ko.observableArray []
@currentPhotos = ko.computed ->
flickr.photos
HTML如下:
<body>
<h4>Photo List</h4>
<ul data-bind="foreach: currentPhotos">
<li>
title: <span data-bind="text: title"> </span>
</li>
</ul>
</body>
我创建的JSBin页面如下:http://jsbin.com/avazak/7/
谢谢你的好意。
由于依赖跟踪在computed observable中的工作方式:
当你的求值器函数运行时,KO会保存一个日志,记录你的求值器读取的任何可观察对象(或计算的可观察对象)的值。
所以你需要在中调用你的可观察对象,引用它们是不够的:
@currentPhotos = ko.computed ->
flickr.photos()
我建议你在Flickr
对象中声明@photos
为ko.observableArray
,而不是在PhotoListViewModel
演示JSFiddle。
相关文章:
- electronic BrowserWindow的最小高度和宽度在hide()show()方法之后不起作用
- 监视函数从服务返回不起作用,但作用域函数起作用
- 幻灯片滚动javascript不起作用
- 简单的javascript在Shopify中不起作用
- Recaptcha在IE7和IE8中不起作用
- Ember Data DS.Model's set函数不起作用
- JsFiddle上的鼠标事件不起作用
- 我的AngularJS表达式没有'不起作用
- 点击按钮输入不起作用
- 面向对象的Javascript代码在IE7中不起作用
- 分部隐藏在jquery中不起作用
- 在phonegap应用程序内部重定向不起作用
- Array.length似乎不起作用;console.log则显示其他情况
- $ionicplatform内的$scope不;不起作用
- 我的javascript for循环不起作用
- Meteor-添加用户自定义字段的方法不起作用
- 为什么 .focus() 不起作用,而 .css(“color”,“red”) 在同一个选择器上起作用
- Textarea必需的attribut在javascript中不起作用
- jsbin for 循环不起作用 意外的令牌错误
- 使用Knockout.js的简单Flickr应用程序不起作用(JSBin准备的)