• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

jquery如何给不存在的元素添加事件?

jquery 搞代码 4年前 (2021-12-27) 23次浏览 已收录 0个评论

jquery如何给不存在的元素添加事件?下面本篇文章就来给大家介绍一下。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

问题 :
jquery中给元素添加事件是很简单的,如:添加一个点击事件。

$(选择器).click(function(){ 
);

但是,项目中做了ajax分页,第一页直接加载,使用上述方法,完全没有问题。但是用在使用ajax分页,其它页的内容,都是后面通过innerHTML来进行添加,添加后的元素就没有相关的事件了。

其实,原因也很好理解就是在最开始添加事件时,其它页的元素并不存在,后面通过innerHTML添加后,标签是有了,但是对应的事件却是没有的。

那么,如何解决上面的总结呢??给不存在的元素也添加事件

解决方案:

使用live来源gao*daima.com搞@代#码网方法 : 给不存在的元素,绑定事件 。

live() 方法为被选元素附加一个或多个事件处理程序,并规定当这些事件发生时运行的函数。

通过 live() 方法附加的事件处理程序适用于匹配选择器的当前及未来的元素(比如由脚本创建的新元素)。

$("#id").live("click", function () { 
  alert("ok"); 
});

但是,jquery 1.9+版本后,就删除了live方法. 那用什么方法来替换live呢?

答案,就是使用on方法

$("#id").on("click",function(){ 
           alert("ok"); 
   });

但是,使用了on方法,发现还是无效 ,语法没有问题,那为啥没效,答案是不应该这样写,如果是给不存在的元素添加事件,

要使用以下的写法:

$(document).on("click",'#id', 
     function(){ 
        alert("ok"); 
    });

更多web前端开发知识,请查阅 搞代码网 !!

以上就是jquery如何给不存在的元素添加事件?的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:jquery如何给不存在的元素添加事件?

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址