Jquery 在单击事件中使用通用选择器(*)仅选择单击的对象,而不选择父对象
我正在开发一个DOM检查器小书签。我需要用户能够单击页面中的任何内容,因此我必须使用通用选择器(*)将单击事件附加到。但是,当通过该选择器单击某个项目时,我会返回所选项目和每个父项。如何仅获取所选项目,以便处理该项目Jquery 在单击事件中使用通用选择器(*)仅选择单击的对象,而不选择父对象,jquery,Jquery,我正在开发一个DOM检查器小书签。我需要用户能够单击页面中的任何内容,因此我必须使用通用选择器(*)将单击事件附加到。但是,当通过该选择器单击某个项目时,我会返回所选项目和每个父项。如何仅获取所选项目,以便处理该项目 $(document).on("click", "*", function() { alert(this); }); jQuery文档: jQuery文档: “我需要用户能够单击页面中的任何内容,因此我必须使用通用选择器(*)将单击事件附加到。” 您不需要通用选择器,事实
$(document).on("click", "*", function() {
alert(this);
});
jQuery文档:
jQuery文档:
“我需要用户能够单击页面中的任何内容,因此我必须使用通用选择器(*)将单击事件附加到。”
您不需要通用选择器,事实上,您根本不需要第二个参数来指定选择器。当文档接收到click事件时,它可以使用以下命令确定事件以哪个元素开始:
“我需要用户能够单击页面中的任何内容,因此我必须使用通用选择器(*)将单击事件附加到。”
您不需要通用选择器,事实上,您根本不需要第二个参数来指定选择器。当文档接收到click事件时,它可以使用以下命令确定事件以哪个元素开始:
您是对的,尽管警告是(在任何一种情况下)OP的事件处理程序必须在任何其他事件处理程序之前注册,以确保它在任何事件中都获得第一次咬入。@Alnitak-即使上面的事件是先注册的,它也不会(必然)获得第一次咬入,因为直接绑定到元素的处理程序不总是在绑定到文档的委托处理程序之前调用吗?您是指
onclick=“…”
handler?是的,虽然可以删除它们,但添加这个,然后使用addEventListener
@Alnitak重新插入原始文件-不,我的意思是$(“#someElementId”)。单击(…
-你是对的,尽管警告是(在任何情况下)OP的事件处理程序必须在任何其他事件处理程序之前注册,以确保它在任何事件中都得到第一次咬合。@Alnitak-即使上面的事件处理程序是先注册的,它也不会(必然地)得到第一次咬合第一口,因为直接绑定到元素的处理程序不总是在绑定到文档的委托处理程序之前被调用吗?你是指onclick=“…”
handler?是的,虽然可以删除这些处理程序,但添加它,然后使用addEventListener
@Alnitak重新插入原始处理程序-否,我是说$(“#someElementId”)。单击(…
-
$(document).on("click", "*", function(event) {
event.stopPropagation();
});
$(document).on("click", function(event) {
// event.target is the element you care about
alert(event.target.id); // or whatever
...
});