首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用“this”动态添加html代码

使用“this”动态添加html代码
EN

Stack Overflow用户
提问于 2015-03-19 08:51:36
回答 1查看 35关注 0票数 1

所以我指的是这个问题jQuery click event, after appending content

正如我所看到的,我仍然可以通过单击动态添加的html代码来调用函数。

但是,例如,我有以下代码:

代码语言:javascript
复制
for (i = 0; i < 5; i++)
{
    $(".container").after("<div class='article'><input type='button' id='button' /></div>");
}   

$('body').on('click', '#button', function () {
    $(this).parent().addClass("newClass");  // Of course this doesnt work because of 'this'
});

对于动态添加的html代码,我如何仍然使用“this”呢?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-03-19 08:54:53

因为您有一个循环,并且添加了一个具有相同id的元素,因此每个元素都必须是唯一的。

代码语言:javascript
复制
.after("<div class='article'><input type='button' class='button' /></div>");

将其更改为类并使用它:

代码语言:javascript
复制
$('body').on('click', '.button', function () {
    $(this).parent().addClass("newClass"); 
});

你没有提出的问题,但我要提一提,以澄清:

当DOM中有相同的in时会发生什么?

当浏览器使用该id查找DOM节点时,如果它在DOM中找到,则停止查找其他节点。因此,任何绑定在该id上的事件都将只为一个id注册。

下面是测试用例:

代码语言:javascript
复制
$('#button').click(function(){
    alert(this.textContent);
});
代码语言:javascript
复制
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<button id='button'>Click1</button>
<button id='button'>Click2</button>
<button id='button'>Click3</button>
<button id='button'>Click4</button>

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

https://stackoverflow.com/questions/29140277

复制
相关文章

相似问题

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