- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是coffeescript 和javascript 的新手。我写了下面的例子。当bar
时此操作失败被调用。
class FooBar
constructor: ->
@cleanBinding()
@addBinding()
@foo
addBinding: ->
$(document).on 'click', '.foo', @foo
$(document).on 'input', 'input#bar', @bar
cleanBinding: ->
$(document).off 'click', '.foo'
$(document).off 'input', 'input#bar'
foo: ->
alert('foo')
bar: (e) ->
@foo()
e.preventDefault()
@FooBar = FooBar
调用@foo
bar
内被编译为this.foo()
在 JavaScript 中。然而,这失败了,因为this.foo
未定义。奇怪的this
是一个链接,<a href>
。有人可以帮我弄清楚发生了什么事吗?
最佳答案
我想我已经明白你的问题所在了。
真正的问题是如何注册事件处理程序:
$(document).on 'click', '.foo', @foo
因为这里的@foo
只是一个没有任何上下文的FooBar::foo
函数。
有两种方法可以修复它。
<小时/>首先,你可以显式地将@foo
与this
绑定(bind),这是常见的JS解决方案:
$(document).on 'click', '.foo', @foo.bind this
<小时/>
其次,您可以在定义方法时使用 CoffeeScript 粗箭头运算符 =>
:
class FooBar
constructor: ->
@cleanBinding()
@addBinding()
@foo
addBinding: ->
$(document).on 'click', '.foo', @foo
$(document).on 'input', 'input#bar', @bar
cleanBinding: ->
$(document).off 'click', '.foo'
$(document).off 'input', 'input#bar'
foo: =>
alert('foo')
bar: (e) =>
@foo()
e.preventDefault()
当创建 FooBar
类的新实例时,它会自动告诉 CoffeeScript 编译器 .bind()
这些方法。
关于javascript - 无法调用 java/coffeescript 中的实例方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25252397/
我有以下 Coffeescript: $ -> $('#new_event').submit -> $.post( $(this).attr('acti
Coffeescript docs包含以下简介 String Interpolation, Block Strings, and Block Comments Ruby-style string in
如何获得类似于 HTML 的 target='_blank' 的行为在 CoffeeScript 里面? 到目前为止,我已经尝试过: window.location = "/site/#{pk}/go
array = [1,2,3,4] for num in array //do something num的值是多少在函数的其余部分?是否num得到范围到循环? 最佳答案 不,num不会被限制
Coffeescript 使用存在运算符来确定变量何时存在,并且在 coffeescript documentation 中它表明 something?将编译为 something !== undef
我一直在阅读一些关于 coffeescript 的继承模型的内容,我感觉自己正处于一场我真的不理解的意识形态辩论的边缘。所以,我会非常高兴地发现我只是以错误的方式做事。 基本上我正在做的是编写一组小部
这个问题在这里已经有了答案: How to iterate over the keys and values in an object in CoffeeScript? (4 个回答) 8年前关闭。
让我们定义这个简单的代码: class Foo @foo = 'blah' console.log(@foo) class Bar extends Foo constructor: ()
除了这些示例之外,我正在努力寻找任何好的 CoffeeScript 和模式匹配示例: {x, y} = sprite css = {opacity, fontFamily} 我在 Erlang 中使用
我想做一个 if 语句来检查一个对象是否是一个空对象。 空对象是指如果我执行 console.log(object) 它会打印出 {}。 我该怎么做呢? 最佳答案 myObject = {} if O
在 JS 中创建文字数组时: [{ name: 'david', value: 'blue' }, { name: 'harold', value: 'orange' }] 我能看到在 Coffees
我的问题类似于发布的 here .本质上我想读一个配置file.json看起来像这样: { "message": "Error in #{baseName} at #{directory}" }
如果我有一个类,则将多个参数传递给: class Foo constructor: (parameters) -> @bar = parameters.bar @moo = paramet
coffeescript中是否有 namespace 的内在支持? 适当的命名空间似乎确实可以帮助Coffeescript有所帮助,尽管我似乎无法找到任何迹象表明存在对此的支持。 最佳答案 既可以在自
我有一个具有一些jquery事件侦听器的coffeescript类。我想使用粗箭头=>以避免引用该类,但是我仍然需要引用通常与this一起使用的元素。如何同时使用两者? class PostForm
我要转换 console.log({ a: 'a' }, { b: 'b' }); 进入 CoffeeScript。我发现的唯一方法是 console.log a: 'a', b:
我真的很喜欢这个: var value = maxValue > minValue ? minValue : maxValue; Coffeescript 中是否有同样简洁的东西? 最佳答案 valu
我想在coffeescript中编写一个静态帮助器类。这可能吗? 类别: class Box2DUtility constructor: () -> drawWorld: (world, co
super 简单的coffeescript问题 circles = [] for coordinate, i in coordinates circles[i] = new MakeCircl
我在看this great video由 Jeremy 在 CoffeeScript 上发表。他解释说,CoffeeScript 的理想之一是让“一切都是表达式”。 CoffeeScript 离这个理
我是一名优秀的程序员,十分优秀!