您好,登录后才能下订单哦!
这篇文章主要介绍“如何解决UpdatePanel和jQuery不兼容”,在日常操作中,相信很多人在如何解决UpdatePanel和jQuery不兼容问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何解决UpdatePanel和jQuery不兼容”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
															在做项目中发现,在使用了UpdatePanel的地方,局部刷新后,jquery失效了。 
后来才发现,jquery中的ready事件会在DOM完全加载后运行一次,而当我们实用了UpdatePanel,它只局部更新,并未重新加载页面所有Dom,所以jquery中ready事件将不会再次执行。所以,我们可以将ready事件中执行的代码提取出来,然后通过捕获ScriptManager的EndRequest事件,在每次 UpdatePanel局部刷新之后执行一次jQuery初始化代码: 
复制代码 代码如下:
//处理ajax和ScriptManager的冲突 
function load() { 
Sys.WebForms.PageRequestManager.getInstance().add_endRequest(EndRequestHandler); 
} 
function EndRequestHandler() { 
$(function () { 
$("tbody").find("input:checkbox").each(function (key, val) { 
$(val).click(function () { 
var cbxId = $(this).attr("id"); 
var state = $(this).attr("checked"); 
$.post("Ajax/UpdateStatus.ashx", { "id": cbxId, "isChecked": state, "fid": "SamID" }, isReturnStatus); 
}); 
}); 
$("thead").find("input:checkbox").click( 
function () { 
if (confirm("确定要更新这一列数据吗?") == true) { 
var cbxId = $(this).attr("id"); 
var name = cbxId.substr(16); 
var v = "tbody ." + name + " input[type='checkbox']"; 
if ($(this).attr("checked") == "checked") { 
$(v).attr("checked", true); 
} 
else { 
$(v).attr("checked", false); 
} 
var state = $(this).attr("checked"); 
$.post("Ajax/UpdateStatus.ashx", { "id": cbxId, "isChecked": state }, isReturnStatus); 
} 
else { 
if ($(this).attr("checked") == "checked") { 
$(this).attr("checked", false); 
} 
else { 
$(this).attr("checked", true); 
} 
} 
}); 
}); 
initCheckedStaus(); 
} 
到此,关于“如何解决UpdatePanel和jQuery不兼容”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。