Coffeescapet jQCloud处理程序
Coffeescript jQCloud handlers
我正试图在coffeescript、中做到这一点
http://jsfiddle.net/Q6348/8/
具体来说,我正试图将处理程序添加到我的jQWordCloud中,以获得上点击的单词的标签
在我的咖啡脚本版本中
while i < @counts.length
x = @counts[i]
@tag_list.push
text: x.label
weight: x.count
handlers:
click: ->
temp = x
->
alert "it worked for " + temp.label
()
++i
我得到了一个意外的TERMINATOR错误,可能是因为(),但如果您在jsfiddle上注意到,删除它会破坏处理程序
解决此问题的常用CoffeeScript方法是使用do
:
当使用JavaScript循环生成函数时,通常会插入闭包包装器,以确保循环变量是封闭的,并且所有生成的函数不仅仅共享最终值。CoffeeScript提供了
do
关键字,该关键字会立即调用传递的函数,转发任何参数。
然后只需使用普通的for ... in
而不是while
循环,这样就不必在索引上乱搞;更像这样的东西:
for o in stuff
do (o) ->
tag_list.push
text: o.NAME
weight: o.COUNT
html:
title: "#{o.COUNT} varieties"
handlers:
click: -> console.log("it worked for", o)
演示:http://jsfiddle.net/ambiguous/3W9YC/
或者你可以使用这样的循环理解:
tag_list = for o in stuff
do (o) ->
text: o.NAME
weight: o.COUNT
html:
title: "#{o.COUNT} varieties"
handlers:
click: -> console.log("it worked for", o)
并且避免CCD_ 5呼叫。
演示:http://jsfiddle.net/ambiguous/3W9YC/1/
顺便说一句,您可以在jsfiddle.net上使用CoffeeScript,方法是在侧边栏的Languages面板中选择它。
相关文章:
- keyup事件处理程序更改焦点不适用于快速键入
- Webpack/Rect:遵循egghead.io教程,但出现错误:您可能需要一个合适的加载程序来处理此文件类型
- 提示使用服务器端事件处理程序激活JavaScript
- 将事件处理程序绑定到任何可能的事件
- 正在将事件处理程序添加到不存在的类
- 在AJAX回调和呈现PIXIJS之间处理程序流时遇到了问题
- Adobe Edge:动画完成时添加onComplete处理程序
- 是否可以从输入处理程序中确定输入的类型
- 在MVVM视图模型中处理应用程序范围的元素
- 在循环中附加事件处理程序时出现浏览器性能问题
- 在同一个javascript事件处理程序中调用不同的函数
- 有没有一种方法可以让内联事件处理程序在元素创建后立即执行
- 检查事件处理程序参数
- 实现延迟的jquery更改事件处理程序
- 如何使用Python/Selenium网络驱动程序处理Angularjs/Javascript下拉列表
- 在 AJAX 完成之前,不要让其他处理程序处理
- 如何使用硒铬驱动程序处理地理位置弹出窗口
- 如何使用硒网络驱动程序处理 onblur 事件
- 是否有一种方法为chrome打包应用程序处理Http BasicAuthentication
- Ajax加载程序处理问题