JQ动态生成节点绑定事件无效问题
最近做项目的时候遇见了一个问题,通过jq将动态节点绑定到dom节点上,并且为动态节点绑定方法,此方法再次为动态节点添加动态节点,但在刷新之后,动态节点上的方法失效了,过程为:创建动态节点->动态节点绑定方法->添加动态节点->刷新后点击动态节点方法失效。
<!DOCTYPE html>
<html>
<head></head>
<body>
<div id="liData">
</div>
</body>
</html>
1、首先通过ajax获取到管理员管理多少个班级
-------------------
| 班级1 |
-------------------
| 班级2 |
-------------------
| |
| |
| |
| |
| |
| |
-------------------
...ajax
success: function (res) {
for (i = 0; i < res.data.length; i++) {
var collegeList = '<ul class="......">' +
'<li class="......">' +
'<a class="......" onclick="getPro(\''+res.data[i].ID+'\')">' + res.data[i].FullName + '</a>' +
'<div class="......" id="' + res.data[i].ID + '">' +
'</div>'
'</li>' +
'</ul>';
$("#liData").append(collegeList);
}
......
2、点击对应班级添加班级学生
--------------------
| 班级1(active) |
--------------------
| 学生1 |
| 学生2 |
| 学生3 |
| 学生4 |
| 学生... |
-------------------
| 班级2 |
| |
--------------------
Function getPro(id){
...ajax
success: function (ress) {
for (j = 0; j < ress.data.length; j++) {
var list = '<li class="...... ">' +
'<a class="......">' +
'<p class="......">姓名:' + ress.data[j].StudentName + '</p>' +
'<p class="......">学号:' + ress.data[j].StudentID + '</p>' +
'<p class="......">性别:' + ress.data[j].Sex + '</p>' +
'<p class="......">院系:' + ress.data[j].College + '</p>' +
'<p class="......">专业:' + ress.data[j].ProfessionalName + '</p>' +
'<p class="......">班级:' + ress.data[j].OrganName + '</p>' +
'</a>' +
'</li>';
$("#" + id+ "").append(list);
}
}
}
......
3、刷新后会发现,点击班级加载不出学生来,于是采用同步加载的方式勉强实现
...ajax
success: function (res) {
for (i = 0; i < res.data.length; i++) {
var OrganID = res.data[i].ID;
var collegeList = '<ul class="......">' +
'<li class="mui-table-view-cell mui-collapse">' +
'<a class="......">' + res.data[i].FullName + '</a>' +
'<div class="......" id="' + res.data[i].ID + '">' +
'</div>'
'</li>' +
'</ul>';
$("#liData").append(collegeList);
$.ajax({
......
async: false,//同步,但并非好办法
success: function (ress) {
for (j = 0; j < ress.data.length; j++) {
var list = '<li class="...... ">' +
'<a class="......" onclick="showInfo(' + ress.data[j].StudentID + ')">' +
'<p class="......">姓名:' + ress.data[j].StudentName + '</p>' +
'<p class="......">学号:' + ress.data[j].StudentID + '</p>' +
'<p class="......">性别:' + ress.data[j].Sex + '</p>' +
'<p class="......">院系:' + ress.data[j].College + '</p>' +
'<p class="......">专业:' + ress.data[j].ProfessionalName + '</p>' +
'<p class="......">班级:' + ress.data[j].OrganName + '</p>' +
'</a>' +
'</li>';
$("#" + OrganID + "").append(list);
}
}
})
}
}
4、网上找了很多解决方案,学习了委托,其作用在于
1)提高性能
对于多个相同的操作,如果足一操作,会影响性能
2)重复事件
新添加了元素还要触发之前的事件,而之前事件已经执行完,导致不再触发(我的错误就属于此类)
$("...").click(function(){
let list='<button class="btn">jq添加节点</button>';
$("...").append(list);
})
$("btn").click(function(){
//方法无效
})
$("父节点").on('click','button',function(){
//通过事件委托完成,有效
})
ps:当时很想明白我犯的错误的原理,但网上全是例子,没有详细说明原因,很是苦恼,最后找到一个讲解比较详细还很通俗易懂的帖子,分享给大家:
https://blog.csdn.net/a_csdner/article/details/76164986
小结:
$('...').bind('click',function(){
//这就是事件不委托,每个按钮有自己的事件
})
$('#btn').delegate('.button','click',function(){
//这就是事件委托,
})
$('#btn').undelegate('.button','click')//取消绑定
JQ动态生成节点绑定事件无效问题的更多相关文章
- jQuery使用on()绑定动态生成元素的事件无效
jquery on()方法是jquery1.7+后才使用的 由于需求:动态添加了以下代码 <tr class="pj" data-val="no"> ...
- jQuery1.9之后使用on()绑定 动态生成元素的 事件无效
来自互联网: 需要绑定a的父级元素(此元素必须为静态元素,不是后来动态生成的),然后设定on()方法的selector参数才行: $('p').on('mouseenter', 'a', functi ...
- 关于 js 动态生成html 绑定事件失效的问题
在实际问题中,也只到使用新版jq 的on 事件 进行动态元素的绑定: 是这样 (但是依然没有效果——): $('dom节点').on('click',function(){}) 之后经过查阅发现:正确 ...
- 关于动态生成dom绑定事件失效的原因
之前做项目都是直接用jquery的bind绑定事件,不过当时都不是动态生成dom元素,而是已经页面中原本存在的dom元素进行事件绑定,最近在测试给动态生成的dom绑定事件的时候发现事件失效,于是就测试 ...
- Vue2.x与bootsrap-table动态添加元素和绑定事件无效
一.问题: 最近在使用vue与bootstrap-table结合生成表格时,按以前的经验----每列数据可用formatter:function(value,row,index){}进行一些其 ...
- jQuery1.9及其以上版本中动态元素on绑定事件无效解决方案
jQuery 1.9/2.0/2.1及其以上版本无法使用live函数了,然而jQuery 1.9及其以上版本提供了on函数来代替.本文讲解了jQuery on函数的使用方法,以及在使用jQuery函数 ...
- jquery 动态创建的元素,绑定事件无效之解决方法
今天遇到一个问题,动态创建的元素,绑定事件无效,如下: js 代码如下: var OaddX = $('.detright div.duibi div.duibox ul li span'); // ...
- 如果dom节点是动态添加进页面的,在页面节点绑定事件如何解决的问题。
如果dom节点是动态添加进页面,想在节点绑定事件,传统的做法就是遍历节点,但会出现问题,也肯能有其他的办法,突然想到 可以依据事件冒泡,这样就不惧页面后添加节点而不响应事件的问题.比较结实.示例代码如 ...
- jquery生成元素注册事件无效,及事件委托的使用
在页面加载完成之后,我们在页面操作用js生成html代码到页面,动态的添加元素带页面上 但是,这里可能很多人就必须碰到的一个问题就出现了,当你之后动态添加了元素到页面上,发现这个元素的绑定事件无效,如 ...
随机推荐
- numpy 和 tensorflow 中的各种乘法(点乘和矩阵乘)
点乘和矩阵乘的区别: 1)点乘(即" * ") ---- 各个矩阵对应元素做乘法 若 w 为 m*1 的矩阵,x 为 m*n 的矩阵,那么通过点乘结果就会得到一个 m*n 的矩阵. ...
- Python【day 15】基本数据类型-int str bool list
'''''' ''' 1 python的定义 是一门弱类型的解释性的高级编程语言 这里的高级是相对低级(例如:汇编语言等) 高级编程语言和低级编程语言的区别 1.前者更接近于人的理解--字母组成的语法 ...
- ojdbc.jar在maven中报错(下载不了)
一.问题 由于oracle的版权问题,java连接oracle的jar(ojdbc.jar)在maven的中央仓库下载不到,然后导致maven项目报错. 二.解决 第一步:下载ojdbc.jar 由于 ...
- JavaScript之找LHS查询和RHS查询
LHS和RHS,当变量出现在赋值操作的左侧时进行LHS 查询,出现在右侧时进行RHS 查询. LHS 查询是试图找到变量的容器本身,从而可以对其赋值. RHS 理解成retrieve his sour ...
- 实验吧简单的SQL注入1,简单的SQL注入
接上面一篇博客. 实验吧简单的sql注入1 题目连接 http://ctf5.shiyanbar.com/423/web/ 同样,直接输入 1加个但引号,结果下面有返回错误, ...
- Linux实现免密码登录
一.验证ssh远程登录,未作免密处理的两台机器,登录时,是需要输入密码的 二.本地系统执行 ssh-keygen -t rsa 命令,生成密钥文件 三.在相应的目录下查看生成的密钥文件,其中:id_r ...
- 数据库 OR 运维 ____bayaim
最近一直在思考,想想未来的道路和自己努力的方向.马云曾说过现在的年轻人缺少“慢下来”,只有人慢下来才能更好思考,想好方法和目标才更靠近才成功.如果,一直不停的努力,在错误的道路越走越远,势必会浪费时间 ...
- FileSizeLimitExceededException
org.apache.tomcat.util.http.fileupload.FileUploadBase$FileSizeLimitExceededException 很明显,这异常的意思是文件大小 ...
- Day_02
1.无参数无返回值函数的使用 package main import "fmt" //无参无返回值函数的定义 func MyFunc() { a := 666 fmt.Printl ...
- postman---postman发送请求
前面简单的介绍了Postman的页面介绍和功能介绍,今天我们一起学习postman如何发送请求 发送请求 我们介绍过http协议有多种请求方式,各个请求方法都代表不同的结果.例如,GET使您可以从服务 ...