我有一段代码,我循环浏览页面上的所有选择框,并将一个悬停事件绑定到它们上,以便在鼠标打开/关闭时对它们的宽度进行一些微调。

这在页面就绪时发生,工作正常。

我遇到的问题是,在初始循环之后通过Ajax或DOM添加的任何选择框都不会绑定事件。

我已经找到了这个插件(jQuery Live Query插件),但在我用插件向我的页面添加另一个5k之前,我想看看是否有人知道这样做的方法,无论是直接使用jQuery还是通过另一个选项。


当前回答

您可以简单地将事件绑定调用包装成一个函数,然后调用它两次:一次在文档就绪时调用,一次在添加新DOM元素的事件之后调用。如果这样做,您将希望避免在现有元素上绑定同一事件两次,因此您需要解除现有事件的绑定,或者(更好)只绑定到新创建的DOM元素。代码看起来像这样:

function addCallbacks(eles){
    eles.hover(function(){alert("gotcha!")});
}

$(document).ready(function(){
    addCallbacks($(".myEles"))
});

// ... add elements ...
addCallbacks($(".myNewElements"))

其他回答

当使用jQuery(html,属性)动态创建时,可以将事件附加到元素。

从jQuery1.8开始,任何jQuery实例方法(jQuery.fn的方法)都可以用作传递给第二个参数:

函数handleDynamicElementEvent(事件){console.log(事件类型,此值)}//创建事件并将其附加到动态元素jQuery(“<select>”{html:$.map(数组(3),函数(_,索引){返回新选项(索引,索引)}),日期:{更改:handleDynamicElementEvent}}).appendTo(“正文”);<script src=“https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

jQuery.fn.on的文档中有一个很好的解释。

简而言之:

事件处理程序仅绑定到当前选定的元素;它们必须在代码调用.on()时存在于页面上。

因此,在下面的示例#dataTable中,生成代码之前必须存在tbodytr。

$("#dataTable tbody tr").on("click", function(event){
    console.log($(this).text());
});

如果新的HTML被注入到页面中,最好使用委托事件来附加事件处理程序,如下所述。

委派事件的优点是,它们可以处理来自后代元素的事件,这些后代元素稍后会添加到文档中。例如,如果表存在,但行是使用代码动态添加的,下面将处理它:

$("#dataTable tbody").on("click", "tr", function(event){
    console.log($(this).text());
});

除了处理尚未创建的后代元素上的事件的能力之外,委托事件的另一个优点是,当必须监视许多元素时,它们可以大大降低开销。在tbody中有1000行的数据表上,第一个代码示例将处理程序附加到1000个元素。

委托事件方法(第二个代码示例)只将事件处理程序附加到一个元素tbody,并且事件只需要向上冒泡一个级别(从单击的tr到tbody)。

注意:委派事件不适用于SVG。

创建对象时,可以将事件添加到对象中。如果您在不同的时间向多个对象添加相同的事件,那么创建命名函数可能是一种方法。

var mouseOverHandler = function() {
    // Do stuff
};
var mouseOutHandler = function () {
    // Do stuff
};

$(function() {
    // On the document load, apply to existing elements
    $('select').hover(mouseOverHandler, mouseOutHandler);
});

// This next part would be in the callback from your Ajax call
$("<select></select>")
    .append( /* Your <option>s */ )
    .hover(mouseOverHandler, mouseOutHandler)
    .appendTo( /* Wherever you need the select box */ )
;
<html>
    <head>
        <title>HTML Document</title>
        <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/1.12.0/jquery.min.js"></script>
    </head>

    <body>
        <div id="hover-id">
            Hello World
        </div>

        <script>
            jQuery(document).ready(function($){
                $(document).on('mouseover', '#hover-id', function(){
                    $(this).css('color','yellowgreen');
                });

                $(document).on('mouseout', '#hover-id', function(){
                    $(this).css('color','black');
                });
            });
        </script>
    </body>
</html>

将事件绑定到已存在的父级:

$(document).on("click", "selector", function() {
    // Your code here
});