最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

在jquery中给动态生成的标签绑定事件(详细教程)

来源:懂视网 责编:小OO 时间:2020-11-27 19:41:04
文档

在jquery中给动态生成的标签绑定事件(详细教程)

经常遇到给动态生成的标签绑定事件不好用,自己简单测试总结了下,结论如下了。<;body>;<;,只对已经存在的静态标签好用 $(';li';).bind(';click';.function(event) { alert(";haha";);///根本不会触发这个方法 });})<;/script>;。点击按钮,就会在d2中添加一个li标签,这个可以。但是,如果这样在初始化时,用bind方法给将来要动态生成的li标签绑定方法是无效的,点击生成的li标签,没有任何反应。因为bind方法只能给在执行它时已经存在的静态标签jq对象绑定事件,对未来动态添加的标签是无效的。这时,可以有几种方法来解决这个问题。
推荐度:
导读经常遇到给动态生成的标签绑定事件不好用,自己简单测试总结了下,结论如下了。<;body>;<;,只对已经存在的静态标签好用 $(';li';).bind(';click';.function(event) { alert(";haha";);///根本不会触发这个方法 });})<;/script>;。点击按钮,就会在d2中添加一个li标签,这个可以。但是,如果这样在初始化时,用bind方法给将来要动态生成的li标签绑定方法是无效的,点击生成的li标签,没有任何反应。因为bind方法只能给在执行它时已经存在的静态标签jq对象绑定事件,对未来动态添加的标签是无效的。这时,可以有几种方法来解决这个问题。

下面我就为大家分享一篇jquery 给动态生成的标签绑定事件的几种方法总结,具有很好的参考价值,希望对大家有所帮助。

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

	<body>
	<!-- 下面是用纯动态方式生成标签 -->
	<p id="d2">
	生成a标签
	</p>
	<p id="d3">
	<input type="button" value="生成a标签" id="btn" />
	</p>
	</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>
	<!-- 下面是用纯动态方式生成标签 -->
	<p id="d2">
	动态生成a标签
	</p>
	
	<p id="d3">
	<input type="button" value="生成a标签" id="btn"/>
	
	</p>
	</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>
	<!-- 下面是用纯动态方式生成标签 -->
	<p id="d2">
	生成a标签
	</p>
	
	<p id="d3">
	<input type="button" value="生成a标签" id="btn"/>
	</p>
	</body>
	<script>
	$(function(){
	$('#btn').bind('click', function(event) {
	 /* 在添加标签的同时给添加的标签绑定点击事件 */
	 $("<li>Hello</li>").appendTo("#d2").bind('click', function() {
	 /* 显示标签的内容 */
	 alert($(this).text()); ///这种方式也可以正常打印出 hello
	 });
 	});
 	
	})
	</script>

这种方式是可以解决上面问题的。虽然它用的也是bind方法,但是注意,它是先有目的标签对象然后才调用的bind方法,所以也是好用的。而且它居然可以正常打印自己的信息,非常厉害。

方法三:

<body>
	<!-- 下面是用纯动态方式生成标签 -->
	<p id="d1">
	测试静态标签的绑定方法
	</p>
	<br />
	
	<p id="d2">
	动态生成a标签的位置
	</p>
	<p id="d3">
	<input type="button" value="生成a标签" id="btn" />
	</p>
	</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>

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

在vue中如何使用全局提示框组件?

在vue2中如何使用前端搜索?

在vue中如何做到子组件向父组件传值

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

在jquery中给动态生成的标签绑定事件(详细教程)

经常遇到给动态生成的标签绑定事件不好用,自己简单测试总结了下,结论如下了。<;body>;<;,只对已经存在的静态标签好用 $(';li';).bind(';click';.function(event) { alert(";haha";);///根本不会触发这个方法 });})<;/script>;。点击按钮,就会在d2中添加一个li标签,这个可以。但是,如果这样在初始化时,用bind方法给将来要动态生成的li标签绑定方法是无效的,点击生成的li标签,没有任何反应。因为bind方法只能给在执行它时已经存在的静态标签jq对象绑定事件,对未来动态添加的标签是无效的。这时,可以有几种方法来解决这个问题。
推荐度:
标签: 创建 生成 jQuery
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top