jquery on 动态绑定点击事件

jQuery on()方法绑定动态元素的点击事件无响应的解决办法

作者:山档子 字体:[增加 减小] 类型:转载 时间:2016-07-07 我要评论

这篇文章主要介绍了jQuery on()方法绑定动态元素的点击事件无响应的解决办法的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
?
1
2
3
4
5
6
$( '#check_all' ).on( 'click' , function (){
alert(1);
});
$( "#yujinlist" ).append(html);
count++;
}

以上代码执行时,点击#check_all时,alert一直没反应,后在网上查资料时,才知道on前面的元素也必须在页面加载的时候就存在于dom里面, 那原话是这样的:

支持给动态元素和属性绑定事件的是live和on,其中live在JQUERY 1.7之后就不推荐使用了。现在主要用on,使用on的时候也要注意,on前面的元素也必须在页面加载的时候就存在于dom里面。动态的元素或者样式等,可以放在on的第二个参数里面。

因为我先输出相关html,再执行就没问题了。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
<div class= "row" >\
<div class= "col-xs-12" >\
<div class= "control-group" >\
<label class= "control-label bolder blue" >选择镇街</label>\
<div class= "row" >\
<div class= "checkbox col-xs-1" >\
<label>\
<input type= "checkbox" class= "checkbox" id= "check_all" />\
<span class= "lbl" >全区</span>\
</label>\
</div>\
<div id= "check_item" >\
<div class= "checkbox col-xs-1 " >\
<label>\
<input name= "towm'+count+'" type= "checkbox" class= "checkbox" />\
<span class= "lbl" >西南街道</span>\
</label>\
</div>\
<div class= "checkbox col-xs-1 " >\
<label>\
<input name= "towm'+count+'" type= "checkbox" class= "checkbox" />\
<span class= "lbl" >云东海街道</span>\
</label>\
</div>\
<div class= "checkbox col-xs-1" >\
<label>\
<input name= "towm'+count+'" type= "checkbox" class= "checkbox" />\
<span class= "lbl" >白坭镇</span>\
</label>\
</div>\
<div class= "checkbox col-xs-1" >\
<label class= "block" >\
<input name= "towm'+count+'" type= "checkbox" class= "checkbox" />\
<span class= "lbl" >乐平镇</span>\
</label>\
</div>\
<div class= "checkbox col-xs-1" >\
<label class= "block" >\
<input name= "towm'+count+'" type= "checkbox" class= "checkbox" />\
<span class= "lbl" >大塘镇</span>\
</label>\
</div>\
<div class= "checkbox col-xs-1" >\
<label class= "block" >\
<input name= "towm'+count+'" type= "checkbox" class= "checkbox" />\
<span class= "lbl" >芦苞镇</span>\
</label>\
</div>\
<div class= "checkbox col-xs-1" >\
<label class= "block" >\
<input name= "towm'+count+'" type= "checkbox" class= "checkbox" />\
<span class= "lbl" >南山镇</span>\
</label>\
</div>\
</div>\
</div>\
</div>\
</div>\
</div>\
<hr /> ';
$(' #check_all').on('click' , function(){
var that = this ;
$(' #check_item').find('input:checkbox')
.each( function (){
alert(2);
this .checked = that.checked;
$( this ).closest('.col-xs-1 ').toggleClass(' selected');
});
});

下面看下jquery on() 方法绑定动态元素

jQuery on()方法是官方推荐的绑定事件的一个方法。使用 on() 方法可以给将来动态创建的动态元素绑定指定的事件,例如append等。

?
1
2
3
<div id= "test" >
<div class= "evt" >evt1</div>
</div>

错误的用法,下面方法只为第一个class 为 evt 的div 绑定了click事件,使用append动态创建的div则没有绑定

?
1
2
3
4
5
<script>
// 先绑定事件再添加div
$( '#test .evt' ).on( 'click' , function () {alert($( this ).text())});
$( '#test' ).append( '<div class="evt">evt2</div>' );
</script>

正确的用法如下:

?
1
2
3
4
<script>
$( 'body' ).on( 'click' , '#test .evt' , function () {alert($( this ).text())});
$( '#test' ).append( '<div class="evt">evt2</div>' );
</script>

以上所述是小编给大家介绍的jQuery on()方法绑定动态元素的点击事件无响应的解决办法,希望对大家有所帮助

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值