动态生成的html代码,使用on()方法无法直接绑定。

一、问题描述

  用jQuery的append()方法动态添加了一段html代码之后,发现在为新添加的元素绑定click事件时无法获取该新元素。

二、解决方法

  推荐用on()方法。

     

三、例子      

<!DOCTYPE html>  
<html>  
<head>  
<script src="http://libs.baidu.com/jquery/1.10.2/jquery.min.js">  
</script>  
<script>  
$(document).ready(function(){  
  $("#div1").click(function(){  
    $("<div class='test'>test</div>").appendTo($("#div1"));  
  });  
  $(".test").on("click",function(){  
    $(".test").css("background-color","pink");  
  });  
  $("#div2").bind("click",function(){  
    $(this).css("background-color","pink");  
  });  
});  
</script>  
</head>  
<body>  
   
<h4 style="color:green;">This example demonstrates how to achieve the same effect using on() and bind().</h4>  
   
<div id="div1" style="border:1px solid black;">This is some text.  
<p>Click to set background color using the <b>on() method</b>.</p>  
</div><br>  
   
<div id="div2" style="border:1px solid black;">This is some text.  
<p>Click to set background color using the <b>bind() method</b>.</p>  
</div>  
   
</body>  
</html>  

上面例子中.test元素是动态加载的,但是给它绑定click方法的时候,明明使用了

$(".test").css("background-color","pink");

将背景色设为pink,但是没有起作用,什么原因呢,原因就在于.test是动态加载的元素,而使用上面的方法不能绑定动态加载元素的事件,修正的方法为使用下面的代码代替:

<!DOCTYPE html>  
<html>  
<head>  
<script src="http://libs.baidu.com/jquery/1.10.2/jquery.min.js">  
</script>  
<script>  
$(document).ready(function(){  
  $("#div1").click(function(){  
    $("<div class='test'>test</div>").appendTo($("#div1"));  
  });  
  $(document).on("click",".test",function(){//修改成这样的写法  
    $(".test").css("background-color","pink");  
  });  
  $("#div2").bind("click",function(){  
    $(this).css("background-color","pink");  
  });  
});  
</script>  
</head>  
<body>  
   
<h4 style="color:green;">This example demonstrates how to achieve the same effect using on() and bind().</h4>  
   
<div id="div1" style="border:1px solid black;">This is some text.  
<p>Click to set background color using the <b>on() method</b>.</p>  
</div><br>  
   
<div id="div2" style="border:1px solid black;">This is some text.  
<p>Click to set background color using the <b>bind() method</b>.</p>  
</div>  
   
</body>  
</html>  
究其元素就在于使用$(document)(也可以使用页面的父元素)意义就在于使元素加载完后才执行方法,所以当为jQuery动态加载的元素绑定on方法的时候,使用$(document)设置代码脚本在DOM元素加载完成后开始执行。
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值