我未来追加的元素 是 ajax拼接的
我的on是这样写的
$("td").on("click","a",function(){ alert("Aha!"); });
这是 页面的标签
<td><a class="topic_a" href="#creat" name='${data.context }'>选择</a></td>
ajax拼接标签和上面标签一模一样的 。
但我拼接的标签点击没有效果。
为什么啊?
请确保 你用on绑定的时候 td 已经存在与dom中了..
还有..为什么live 可以 因为live 是绑定在docuement上的..任何时候 document都是存在的..
你用的on 你的事件是绑定在td上的..如果当td不存在的时候 肯定就绑定不上了
请多了解 事件代理机制.
用delegate来替换吧
未来追加的元素中包括 b6c5a531a458a2e790c1fd6421739d1c 么?
包括 b6c5a531a458a2e790c1fd6421739d1c 的话就不能在 $("td")上绑定事件代理。
应该在更上层的元素上绑定事件代理
比如f5d188ed2c074f8b944552db028f98a1或者f5d188ed2c074f8b944552db028f98a1的父元素
实在不行在body或者document上绑定也可以
如
$("body").on("click","a",function(){ alert("Aha!"); });
用on bind 这种。
先拼接,然后添加到页面上,接下里在绑定事件。
js里面,一样是逐行读取的。
绑定事件写在前面,之后来添加的td,当然就不会有这个事件。
同时确保,td已经写入到页面当中。
live方法是旧版本的jquery才有,on方法只能使用在页面上已有的标签;
想获取未来元素,只能用delegate方法了,具体写法如下:
//div是页面已经有的元素,button是js生成的未来元素! $("div").delegate("button","click",function(){ $("p").slideToggle(); });
$(document).on('click', 'td a', function() { alert("Aha!"); });
$("body").delegate("td","click",function(){ alert("ok!"); });
请确保 你用on绑定的时候 td 已经存在与dom中了..
还有..为什么live 可以 因为live 是绑定在docuement上的..任何时候 document都是存在的..
你用的on 你的事件是绑定在td上的..如果当td不存在的时候 肯定就绑定不上了
请多了解 事件代理机制.
你这样写吧
$("body").on("click","td a.topic_a",function(){ alert("Aha!"); });
未来追加的元素中包括 b6c5a531a458a2e790c1fd6421739d1c 么?
包括 b6c5a531a458a2e790c1fd6421739d1c 的话就不能在 $("td")上绑定事件代理。
应该在更上层的元素上绑定事件代理
比如f5d188ed2c074f8b944552db028f98a1或者f5d188ed2c074f8b944552db028f98a1的父元素
实在不行在body或者document上绑定也可以
如
$("body").on("click","a",function(){ alert("Aha!"); });
以上是 jquery中live方法换on方法出现问题的解决办法详解的详细内容。更多信息请关注PHP中文网其他相关文章!

实现方法:1、用“$("img").delay(毫秒数).fadeOut()”语句,delay()设置延迟秒数;2、用“setTimeout(function(){ $("img").hide(); },毫秒值);”语句,通过定时器来延迟。

区别:1、axios是一个异步请求框架,用于封装底层的XMLHttpRequest,而jquery是一个JavaScript库,只是顺便封装了dom操作;2、axios是基于承诺对象的,可以用承诺对象中的方法,而jquery不基于承诺对象。

修改方法:1、用css()设置新样式,语法“$(元素).css("min-height","新值")”;2、用attr(),通过设置style属性来添加新样式,语法“$(元素).attr("style","min-height:新值")”。

增加元素的方法:1、用append(),语法“$("body").append(新元素)”,可向body内部的末尾处增加元素;2、用prepend(),语法“$("body").prepend(新元素)”,可向body内部的开始处增加元素。

在jquery中,apply()方法用于改变this指向,使用另一个对象替换当前对象,是应用某一对象的一个方法,语法为“apply(thisobj,[argarray])”;参数argarray表示的是以数组的形式进行传递。

删除方法:1、用empty(),语法“$("div").empty();”,可删除所有子节点和内容;2、用children()和remove(),语法“$("div").children().remove();”,只删除子元素,不删除内容。

on()方法有4个参数:1、第一个参数不可省略,规定要从被选元素添加的一个或多个事件或命名空间;2、第二个参数可省略,规定元素的事件处理程序;3、第三个参数可省略,规定传递到函数的额外数据;4、第四个参数可省略,规定当事件发生时运行的函数。

去掉方法:1、用“$(selector).removeAttr("readonly")”语句删除readonly属性;2、用“$(selector).attr("readonly",false)”将readonly属性的值设置为false。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

VSCode Windows 64位 下载
微软推出的免费、功能强大的一款IDE编辑器

WebStorm Mac版
好用的JavaScript开发工具

DVWA
Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

Atom编辑器mac版下载
最流行的的开源编辑器