当前位置: 首页 > 面试题库 >

如何使用jQuery将事件附加到动态HTML元素?[重复]

柯伟志
2023-03-14
问题内容

假设我有一些jQuery代码,将事件处理程序附加到class所有元素.myclass

例如:

$(function(){
    $(".myclass").click( function() {
        // do something
    });
});

我的HTML可能如下所示:

<a class="myclass" href="#">test1</a>
<a class="myclass" href="#">test2</a>
<a class="myclass" href="#">test3</a>

没问题。但是,请考虑是否.myclass在以后的某个时间将元素写入页面。

例如:

<a id="anchor1" href="#">create link dynamically</a>
<script type="text/javascript">
$(function(){
    $("#anchor1").click( function() {
        $("#anchor1").append('<a class="myclass" href="#">test4</a>');
    });
});
</script>

在这种情况下,test4当用户单击时将创建链接a#anchor1

test4链接不具备click()与之关联的处理程序,即使它有class="myclass"

基本上,我想编写click()一次处理程序,并将其应用于页面加载时出现的内容以及以后通过 AJAX / DHTML
引入的内容。知道我该如何解决吗?


问题答案:

我正在添加一个新答案,以反映jQuery更高版本中的更改。从jQuery 1.7开始不推荐使用.live()方法。

从http://api.jquery.com/live/

从jQuery
1.7开始,不推荐使用.live()方法。使用.on()附加事件处理程序。较旧版本的jQuery的用户应优先使用.delegate()而不是.live()。

对于jQuery 1.7+,您可以使用.on()将事件处理程序附加到父元素,然后将选择器与“ myclass”组合作为参数传递。

所以代替…

$(".myclass").click( function() {
    // do something
});

你可以写…

$('body').on('click', 'a.myclass', function() {
    // do something
});

这将适用于主体中带有“ myclass”的所有标签,无论该标签已经存在还是以后动态添加。

这里使用body标签,因为该示例没有更紧密的静态周围标签,但是在发生.on方法调用时存在的任何父标签都可以使用。例如,列表的ul标签将添加动态元素,如下所示:

$('ul').on('click', 'li', function() {
    alert( $(this).text() );
});

只要ul标签存在,它将起作用(尚不存在li元素)。



 类似资料:
  • 问题内容: 我想将onclick事件绑定到我使用jQuery动态插入的元素 但是它从不运行绑定函数。如果您能指出此示例为何不起作用以及如何使其正常运行,我将不胜感激: 编辑:我编辑了该示例以包含方法插入到其中的两个元素。在这种情况下,将永远不会执行该调用。 问题答案: 第一个问题是,当您在具有多个元素的jQuery集合上调用append时,会为每个元素创建要添加的元素的克隆,因此丢失了附加的事件观

  • 问题内容: 我正在尝试将html数据动态地插入到动态创建的列表中,但是当我尝试为动态创建的按钮附加onclick事件时,则不会触发该事件。解决方案将不胜感激。 JavaScript代码: }); HTML代码: 问题答案: 这是由于您的元素是动态创建的。您应该使用事件委托来处理事件。 jQuery使它更容易:

  • 问题内容: 我正在上传多个图像,并将它们放置在ondiv必须切换某些类的某些div中。我是否必须将添加onclick事件的部分放在ajax成功函数中?非常感谢! 我正在使用“ on”上的jquery,但似乎不起作用。可能我缺少了一些东西 这是我的代码: Javascript: HTML: 问题答案: 对于动态创建的元素,您必须使用.live()但是,在1.7中不推荐使用,而在中将其完全删除。该签名

  • 问题内容: 我有以下代码: Angular2中 有什么方法可以将HTML添加到中吗?因为上述内容仅添加到组件HTML的末尾。 我也尝试过: 但这是行不通的,因为@ViewChild指令必须在函数之外,我再也无法控制它了 我也这样尝试过: 我不能做的事情是因为我的内容是动态的并且使用唯一的ID,并且我不能动态使用[innerHtml](它仅适用于我第一次放入它们的面板,然后其他任何更改都不能再使用i

  • 本文向大家介绍jquery html动态添加的元素绑定事件详解,包括了jquery html动态添加的元素绑定事件详解的使用技巧和注意事项,需要的朋友参考一下 在实际开发中会遇到要给动态生成的html元素绑定触发事件的情况: 假设我们要给ul动态添加的<li>绑定click事件形成如下结果 以上这篇jquery html动态添加的元素绑定事件详解就是小编分享给大家的全部内容了,希望能给大家一个参考

  • 问题内容: 我想将一个事件处理程序添加到一个段落中,以供任何用户单击它时使用。例如,我有一个段落,当用户单击它时会显示一个警报,但是在HTML上不使用“ onclick”。 问题答案: 您可以添加事件侦听器。 嗯 像这样: 完整代码(已在Chrome&IE7中测试):