首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >迭代元素,将单击事件添加到每个元素中

迭代元素,将单击事件添加到每个元素中
EN

Stack Overflow用户
提问于 2013-08-24 18:44:29
回答 1查看 3.6K关注 0票数 2

这里是jQuery新手。

如果我有这个html:

代码语言:javascript
复制
<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>

我希望向每个click项添加一个li事件,这样我就可以获得所在元素的id。现在,我只对我所使用的索引发出警告(而且它也不起作用),但是我真的想要我所使用的项的ID,而不是我的选择器返回的数组的索引。

这是我尝试过的,但似乎不起作用,我想我可能对each()click()有错误的理解。

代码语言:javascript
复制
$('#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
  });
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-08-24 18:47:16

这应该是可行的:

代码语言:javascript
复制
$('#floor-selector li').on('click', function() {
    alert('I am the '+$(this).attr('id')+' element');
});

在幕后,jQuery做了一堆魔术,本质上绑定了传递给元素的函数。因此,this引用要单击的元素并将其传递给jQuery functio:$(this)将返回包装在jQuery对象中的元素。当然,您可以直接访问id on this

票数 7
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/18421916

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档