• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >jquery > 解决jquery中动态新增的元素节点无法触发事件问题的两种方法

解决jquery中动态新增的元素节点无法触发事件问题的两种方法

作者: 字体:[增加 减小] 来源:互联网

通过本文主要向大家介绍了jquery获取元素子节点,jquery新增节点,jquery触发ajax元素等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

比如做一个ajax读取留言列表的时候,每条留言后面有个回复按钮,class为“reply”,如果你用的是$(".reply").click(function(){ //do something... }),想必后面通过ajax加载进来的列表中的回复按钮,点击事件会失效。

其实最简单的方法就是直接在标签中写onclick="",但是这样写其实是有点low的,最好的方式还是通过给类名绑定一个click事件。

解决jquery中动态新增的元素节点无法触发事件的问题有两种解决方法,如下:

为了达到更好的演示效果,假设在某个页面的body下有以下结构的代码:

<p id="pLabel">新加一条</p>
<ul id="ulLabel">
 <li class="liLabel">aaa1</li>
 <li class="liLabel">aaa2</li>
 <li class="liLabel">aaa3</li>
</ul>
<script type="text/javascript">
$("#pLabel").click(function(){
 $("#ulLabel").append('<li class="liLabel">aaaQ</li>'); //动态像ul的末尾追加一个新元素
});
</script>

方法一:使用live

live()函数会给被选的元素绑定上一个或者多个事件处理程序,并且规定当这些事件发生时运行的函数。通过live()函数适用于匹配选择器的当前及未来的元素。比如,通过脚本动态创建的元素。

实现如下:

$('.liLabel').live('click', function(){
 alert('OK');
});

方法二:使用on

可以通过on方法绑定事件,可以绑定到它的父级或者body中,实现如下:

$("#ulLabel").on('click','.liLabel',function(){
 alert('OK')
});
或者:
$("body").on('click','.liLabel',function(){
 alert('OK')
});

现在大家可以尝试尝试,是不是问题已经得到解决了,希望这篇文章能够真正的帮助大家。

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 解决jquery中动态新增的元素节点无法触发事件问题的两种方法

相关文章

  • 30个经典的jQuery代码开发技巧
  • jQuery实现可拖动进度条实例代码
  • JQuery中关于jquery.js与jquery.min.js的比较探讨
  • 利用JQuery制作符合Web标准的QQ弹出消息
  • jquery实现页面百叶窗走马灯式翻滚显示效果的方法
  • jQuery中addClass()方法用法实例
  • jQuery实现新消息在网页标题闪烁提示
  • jqTransform form表单美化插件使用方法
  • js实现图片放大缩小功能后进行复杂排序的方法
  • jQuery实现的自定义弹出层效果实例详解

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • jQuery下通过replace字符串替换实现大小图片切换
    • jquery实现倒计时效果
    • 浅谈JQuery+ajax+jsonp 跨域访问
    • 扩展jQuery对象时如何扩展成员变量具体怎么实现
    • jquery 圆形旋转图片滚动切换效果
    • JQuery扩展插件Validate 2通过参数设置验证规则
    • jQuery实现横向带缓冲的水平运动效果(附demo源码下载)
    • jquery 将当前时间转换成yyyymmdd格式的实现方法
    • 让人印象深刻的10个jQuery手风琴效果应用
    • javascript与jquery中跳出循环的区别总结

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有