假设我有一些jQuery代码,它将事件处理程序附加到具有.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>
在本例中,当用户单击#anchor1时,将创建test4链接。
test4链接没有与之关联的click()处理程序,即使它有class="myclass"。
基本上,我希望只编写一次click()处理程序,并将其应用于页面加载时呈现的内容,以及稍后通过AJAX / DHTML引入的内容。知道我该怎么补救吗?
有时这样做(投票最多的答案)并不总是足够的:
$('body').on('click', 'a.myclass', function() {
// do something
});
这可能是一个问题,因为订单事件处理程序被触发。如果你发现自己这样做了,但是因为处理的顺序而引起了问题。你总是可以把它包装到一个函数中,当被调用时“刷新”侦听器。
例如:
function RefreshSomeEventListener() {
// Remove handler from existing elements
$("#wrapper .specific-selector").off();
// Re-add event handler for all matching elements
$("#wrapper .specific-selector").on("click", function() {
// Handle event.
}
}
因为它是一个函数,每当我以这种方式设置侦听器时,我通常会在document ready时调用它:
$(document).ready(function() {
// Other ready commands / code
// Call our function to setup initial listening
RefreshSomeEventListener();
});
然后,每当你添加一些动态添加的元素时,再次调用该方法:
function SomeMethodThatAddsElement() {
// Some code / AJAX / whatever.. Adding element dynamically
// Refresh our listener, so the new element is taken into account
RefreshSomeEventListener();
}
希望这能有所帮助!
问候,
有时这样做(投票最多的答案)并不总是足够的:
$('body').on('click', 'a.myclass', function() {
// do something
});
这可能是一个问题,因为订单事件处理程序被触发。如果你发现自己这样做了,但是因为处理的顺序而引起了问题。你总是可以把它包装到一个函数中,当被调用时“刷新”侦听器。
例如:
function RefreshSomeEventListener() {
// Remove handler from existing elements
$("#wrapper .specific-selector").off();
// Re-add event handler for all matching elements
$("#wrapper .specific-selector").on("click", function() {
// Handle event.
}
}
因为它是一个函数,每当我以这种方式设置侦听器时,我通常会在document ready时调用它:
$(document).ready(function() {
// Other ready commands / code
// Call our function to setup initial listening
RefreshSomeEventListener();
});
然后,每当你添加一些动态添加的元素时,再次调用该方法:
function SomeMethodThatAddsElement() {
// Some code / AJAX / whatever.. Adding element dynamically
// Refresh our listener, so the new element is taken into account
RefreshSomeEventListener();
}
希望这能有所帮助!
问候,