- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有一个项目列表,我想在单击按钮或链接时在项目名称下显示每个项目的更详细描述。例如,一个非常简单的实现是使用 .toggle()。在 Rails 中,我有这样的描述:
<% @products.each do |product| %>
<%= div_for(product, :class => "descriptions") do %>
<%= product.description %>
<% end %>
<input type="button" id="button_<%= product.id %>" value="Show/hide" />
<% end %>
我必须在 javascript/coffeescript 端捕获动态生成的 div id:
jQuery ->
$('#button_?????').click ->
$('#product_ ????').toggle()
但是,我无法让它工作。
另一方面,我也许可以使用类似“.closets()”的方法实现相同的结果,如下所示:
jQuery ->
$('#button').click ->
$('#button').closest('.descriptions').toggle()
但是,我也无法让它工作。这似乎是一项相当简单的任务,但我对 javascript 的经验太少,无法让它发挥作用。如何在 javascript 端捕获这些动态生成的 div?非常感谢任何帮助。
最佳答案
为了从 Rails 中捕获动态生成的 div
,您通常会执行以下操作:
var divs = document.querySelectorAll('.descriptions');
不过请记住,querySelectorAll
不是实时的,因此对 DOM 的任何更改都不会反射(reflect)在 NodeList
中。
正如@MrDanA 所建议的,jQuery 对此有一个很好的解决方案。但是,click
处理程序需要在按钮上而不是描述上。此外,live
已被弃用。它需要替换为 on
。
$('.descriptions').each(function(){
var $this = $(this);
var button = $this.next(); // assuming that the button is the next sibling
button.on('click', function(e) {
$this.toggle();
e.preventDefault(); // to prevent page from jumping to the top of the page
});
});
这应该为您提供一个良好的基线。让我确切知道您希望它如何表现。
关于javascript - 将动态生成的 div id 从 Rails 传递到 javascript/coffeescript,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9471773/
我有以下 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 离这个理
我是一名优秀的程序员,十分优秀!