jQuery 为动态添加的元素绑定事件

在使用jquery的方式为元素绑定事件时,我经常使用bind或者click,但这只能为页面已经加载好的元素绑定事件。像需要用ajax的方式请求远程数据来动态添加页面元素时,显然以上几种绑定事件的方式是无效的,具体写法如下图。

$(selector).bind(event,data,function)
$(selector).click(function)

$("#searchMoveVideoResult ul li").bind("click",function(){
	$(this).css("border","5px solid #000");
});
$("#searchMoveVideoResult ul li").click(function(){
	$(this).css("border","5px solid #000");
});

  

为动态添加的元素绑定事件有以下几种方式:

 

1.delegate():向匹配元素的当前或未来的子元素附加一个或多个事件处理器

$(selector).delegate(childSelector,event,data,function)

示例:

 $("#searchMoveVideoResult").delegate("ul li","click",function(){
    $(this).css("border","5px solid #000");
});

2.live():为当前或未来的匹配元素添加一个或多个事件处理器(jquery1.8版本以前推荐使用该方法;jquery1.8版本之后就不建议使用了,我试了下,也是无效的,所以高版本的jquery推荐使用on()方法绑定事件。)

$(selector).live(event,data,function)

$("#searchMoveVideoResult ul li").live("click",function(){
     $(this).css("border","5px solid #000");
});

3.on():适用于当前及未来的元素(比如由脚本创建的新元素)

$(selector).on(event,childSelector,data,function,map)

$("#searchMoveVideoResult").on("click","ul li",function(){
	$(this).css("border","5px solid #000");
});

  来源:https://blog.csdn.net/xiaozhi_2016/article/details/52184328

转载于:https://www.cnblogs.com/fogwang/p/8670402.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值