首页 > javascript相关 > jquery教程 > 正文

jquery 给动态生成的标签绑定事件的几种方法总结_jquery

2018-12-01 20:52:49

经常遇到给动态生成的标签绑定事件不好用,自己简单测试总结了下,结论如下了:

	<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方法有什么弱点啊!

新手一枚,欢迎大神指正各种错误!

以上这篇jquery 给动态生成的标签绑定事件的几种方法总结就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

  • 相关标签:jquery教程
  • 本文发布HTML5中文学习网 ,转载请注明出处,感谢您!
  • 相关文章


  • 曝网友假装外国人写投诉信 ofo秒退押金并回函致歉
  • 苹果市值缩水逾2000亿美元 遭多家投行下调目标价
  • Asp.net Core与类库读取配置文件信息的方法_实用技巧
  • asp.net在Repeater嵌套的Repeater中使用复选框详解_实用技巧
  • 利用IIS调试ASP.NET网站程序的完整步骤_实用技巧
  • Asp.Net Core轻松学习系列之配置文件_实用技巧
  • ASP.NET 页生命周期概述(小结)_实用技巧
  • 详解ASP.NET Core WebApi 返回统一格式参数_实用技巧
  • 2018年网络流行语有哪些?2018年十大网络流行语盘点
  • 华为首席财务官孟晚舟被暂扣 深圳市政府要求加方立即放人!
  • 独孤九贱(4)_PHP视频教程

    江湖传言:PHP是世界上最好的编程语言。真的是这样吗?这个梗究竟是从哪来的?学会本课程,你就会明白了。 PHP中文网出品的PHP入门系统教学视频,完全从初学者的角度出发,绝不玩虚的,一切以实用、有用...

    独孤九贱(5)_ThinkPHP5视频教程

    ThinkPHP是国内最流行的中文PHP开发框架,也是您Web项目的最佳选择。《php.cn独孤九贱(5)-ThinkPHP5视频教程》课程以ThinkPHP5最新版本为例,从最基本的框架常识开始,将...

    独孤九贱(1)_HTML5视频教程

    《php.cn原创html5视频教程》课程特色:php中文网原创幽默段子系列课程,以恶搞,段子为主题风格的php视频教程!轻松的教学风格,简短的教学模式,让同学们在不知不觉中,学会了HTML知识。 ...

    ThinkPHP5实战之[教学管理系统]

    本套教程,以一个真实的学校教学管理系统为案例,手把手教会您如何在一张白纸上,从零开始,一步一步的用ThinkPHP5框架快速开发出一个商业项目。

    PHP入门视频教程之一周学会PHP

    所有计算机语言的学习都要从基础开始,《PHP入门视频教程之一周学会PHP》不仅是PHP的基础部分更主要的是PHP语言的核心技术,是学习PHP必须掌握的内容,任何PHP项目的实现都离不开这部分的内容,通...

    作者信息

    kevin

    永远在学习的路上!

    相关教程

  • javascript初级视频教程 javascript初级视频教程
  • jquery 基础视频教程 jquery 基础视频教程
  • javascript三级联动视频教程 javascript三级联动视频教程
  • 独孤九贱(3)_JavaScript视频教程 独孤九贱(3)_JavaScript视频教程
  • 独孤九贱(6)_jQuery视频教程 独孤九贱(6)_jQuery视频教程
  • 热门教程