jq给动态生成的标签绑定事件的几种方法
来源:互联网 发布:musical软件 编辑:程序博客网 时间:2024/06/05 23:00
经常遇到给动态生成的标签绑定事件不好用,自己简单测试总结了下,结论如下了:
<body><!-- 下面是用纯动态方式生成标签 --><div id="d2">生成a标签</div><div id="d3"><input type="button" value="生成a标签" id="btn" /></div></body><script>$(function(){$('#btn').bind('click', function(event) { /* 在添加标签的同时给添加的标签绑定点击事件 */ $("<li>Hello</li>").appendTo("#d2"); }); ///bind方法对于动态添加的标签不好使,只对已经存在的静态标签好用 $('li').bind('click', function(event) { alert("haha"); ///根本不会触发这个方法 });})</script>
点击按钮,就会在d2中添加一个li标签,这个可以。
但是,如果这样在初始化时,用bind方法给将来要动态生成的li标签绑定方法是无效的,点击生成的li标签,没有任何反应。
因为bind方法只能给在执行它时已经存在的静态标签jq对象绑定事件,对未来动态添加的标签是无效的。
这时,可以有几种方法来解决这个问题:
方法一:
<body><!-- 下面是用纯动态方式生成标签 --><div id="d2">动态生成a标签</div><div id="d3"><input type="button" value="生成a标签" id="btn"/></div></body><script>$(function() {///点击按钮,给d2动态添加标签$('#btn').bind('click', function() {/* 在添加标签的同时给添加的标签绑定点击事件 */$("<li onclick='show()'>Hello</li>").appendTo("#d2");});})function show() {alert($(this).text());///这样打印出的是空的,没有任何东西,但是方法是会触发的(不能这样打印自己)alert("哈哈");}</script>
这种方法是在动态拼接时就拼接好js原生的要触发的事件,然后把事件方法定义在script标签中。这种方法可以触发li的点击事件。但是如果要用alert($(this).text())这种打印标签自己本身信息的东西的方法,是没有任何结果显示的。这个即使是静态的标签打印自己也是不会有显示的。
要解决这个问题,可以用下面两种方法。
方法二:
<body><!-- 下面是用纯动态方式生成标签 --><div id="d2">生成a标签</div><div id="d3"><input type="button" value="生成a标签" id="btn"/></div></body><script>$(function(){$('#btn').bind('click', function(event) { /* 在添加标签的同时给添加的标签绑定点击事件 */ $("<li>Hello</li>").appendTo("#d2").bind('click', function() { /* 显示标签的内容 */ alert($(this).text()); ///这种方式也可以正常打印出 hello }); }); })</script>
这种方式是可以解决上面问题的。虽然它用的也是bind方法,但是注意,它是先有目的标签对象然后才调用的bind方法,所以也是好用的。而且它居然可以正常打印自己的信息,非常厉害。
方法三:
<body><!-- 下面是用纯动态方式生成标签 --><div id="d1">测试静态标签的绑定方法</div><br /><div id="d2">动态生成a标签的位置</div><div id="d3"><input type="button" value="生成a标签" id="btn" /></div></body><script>$(function(){$('#btn').bind('click', function() { /* 在添加标签的同时给添加的标签绑定点击事件 */ $("<li>Hello</li>").appendTo("#d2"); }); ///bind方法对于动态添加的标签不好使,只对已经存在的静态标签好用 ///用live方法才好用 $('li').live('click', function() { alert($(this).text());///注意,用live还可以这样写,结果是正常的 alert("haha"); }); ///通过 live() 方法附加的事件处理程序适用于匹配选择器的当前及未来的元素(比如由脚本创建的新元素) $('#d1').live('click', function() {///对于静态和动态创建的标签都好使 alert($(this).text());///注意,用live还可以这样写,结果是正常的.这是非常重要的 alert("haha"); });})</script>
这种就是用jq的非常好用的既可以动态也可以静态绑定现在或者未来各种标签的live方法。而且它最神奇的地方是也能 打印自己。我靠,太牛了。以后就用它了。
暂时还没发现这个live方法有什么弱点啊!
新手一枚,欢迎大神指正各种错误!
0 0
- jq给动态生成的标签绑定事件的几种方法
- jq动态生成的元素(标签)添加点击事件
- 第24篇:AngularJS实现给动态生成的元素绑定事件的方法
- jQuery on()方法给动态生成的元素绑定事件----实战分析
- jQuery:如何给动态生成的元素绑定事件?
- jQuery:如何给动态生成的元素绑定事件?
- 如何使用Jquery给动态生成的控件绑定事件
- jQuery:如何给动态生成的元素绑定事件?
- jQuery:如何给动态生成的元素绑定事件?
- AngularJS中,如何给动态生成的元素绑定事件
- JQuery给动态生成的DOM元素绑定点击事件
- js关于给动态生成的元素绑定事件
- jq绑定事件的方法区别
- Jquery 动态生成li标签以及单击事件的绑定
- 关于动态生成的标签无法绑定事件
- JavaScript为动态生成的标签绑定事件-参数
- Jquery动态生成的标签添加绑定事件
- 类似评论、点评的JS标签选择功能(及jq动态绑定事件)
- 玩转java多线程学习篇五 线程的优先级和守护线程
- Windows命令查看MD5
- CORS
- Spring注解详解
- react-native Vibration
- jq给动态生成的标签绑定事件的几种方法
- 值(~a>>3 + 1 )
- thinkPHP 查询数据库字段
- 深入flask之异步非堵塞实现
- 最简单的基于libVLC的例子:最简单的基于libVLC的视频播放器
- 537. Complex Number Multiplication
- hibernate分页查询几次后停止执行
- HTML文档声明
- 《java设计模式》之工厂设计模式