遍历元素,向每个元素添加click事件
Iterate through elements, adding click event to each of them
jQuery新手。
如果我有这个html:
<ul id="floor-selector">
<li id="floor-1">Ground Floor</li>
<li id="floor-2">Second Floor</li>
<li id="floor-3">Third Floor</li>
<li id="floor-4">Premier Floor (Premier Floor)</li>
</ul>
我想为每个li
项添加一个click
事件,这样我就可以获得我所在元素的id
。现在我只收到一个带有我所在索引的警报(它也不起作用),但我真的想要我所在项的ID,而不是选择器返回的数组索引。
这是我尝试过的,但似乎不起作用,我想我可能对each()
或click()
有错误的理解。
$('#floor-selector li').each( function(index, node) {
node.click( function(){ alert('I am on the '+index+'th element'); } );
// but I really want to get the ID of this element
});
这应该有效:
$('#floor-selector li').on('click', function() {
alert('I am the '+$(this).attr('id')+' element');
});
在幕后,jQuery做了一堆魔术,基本上将传递给元素的函数绑定在一起。因此,this
引用您正在单击的元素,并将其传递给jQuery函数:$(this)
将返回封装在jQuery对象中的元素。当然,您可以直接访问this
上的id
。
相关文章:
- 如何将html元素添加到tampermonkey中
- 如何将html元素添加为生成的内容
- 如何向Selectize元素添加渲染和创建方法
- 向html选择元素添加选项
- 在d3中向DOM元素添加了图像,但现在它赢得了't过渡
- 如何将新的键/值对元素添加到现有数组
- 使用docment.createElement向元素添加选项
- ng重复向一个元素添加条件类
- 为li元素添加标题
- 向ckeditor中的多个元素添加内联样式
- Javascript 向影子根中的自定义元素添加函数
- 将伪元素添加到<文本区域>
- 如果类只包含一个特定数字,则向元素添加类
- DOM:将空元素添加到 DOM 和页面重排
- 是否有 jQuery 事件用于何时将元素添加到文档中
- 通过 ajax 使用自定义滚动条向元素添加内容
- 是否可以用D3将svg元素添加到开放层映射中
- 如何将元素添加到动态数组并排除现有元素
- 在AngularJS中将元素添加到作用域时,如何在所有设备上播放声音
- 将图像元素添加到<a>标签