jquery on()绑定的点击事件在js动态新添加的元素上无效,请问为啥

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了jquery on()绑定的点击事件在js动态新添加的元素上无效,请问为啥相关的知识,希望对你有一定的参考价值。

jquery on()绑定的点击事件在js动态新添加的元素上无效,请问为什么
$('.class').on("click",function()……);

$('.class').on("click",function()……);相当于$('.class').bind("click",function()……);
$(document).on("click",'.class',function()……);相当于$('.class').live("click",function()……);
js生成的元素绑定事件必须使用live,但新版的jq,已经淘汰了live,可以用on方法代替,但必须注意写法。
参考技术A 如果你的元素是用click事件append进来的,

$("#aa").on("click", “#children”function()
$(‘.aa’).append("<div id='children' style='border: 1px solid blue;'>children content</div>");
如上如果是append进.aa里,那么需要绑定的点击事件的元素的父元素为.aa。
我也是看了网上很多解决这个问题的方法但是都差不多解决不了问题,我试了一下这么做还真解决了。希望对大家有帮助。
参考技术B 动态js,元素如果重新生是不行的吧,一般都是通过一个不变父级元素绑定,$().on(‘click ‘,’元素选择器’,function)写法和你那差不多

以上是关于jquery on()绑定的点击事件在js动态新添加的元素上无效,请问为啥的主要内容,如果未能解决你的问题,请参考以下文章

js 为动态添加的元素绑定事件

JQuery .on() 没有将点击事件绑定到动态创建的元素[重复]

关于jQuery中动态生成的点击事件触发两次的讨论

jQuery on()方法绑定动态元素的点击事件无响应的解决办法

JS动态插入HTML后不能执行后续JQUERY操作

jQuery对 动态添加 的元素 绑定事件(on()的用法)