UpdatePanel和jQuery不兼容 局部刷新jquery失效
2018-10-12 14:07
465 查看
在做项目中发现,在使用了UpdatePanel的地方,局部刷新后,jquery失效了。
后来网上一查,才发现,jquery中的ready事件会在DOM完全加载后运行一次,而当我们实用了UpdatePanel,它只局部更新,并未重新加载页面所有Dom,所以jquery中ready事件将不会再次执行。所以,我们可以将ready事件中执行的代码提取出来,然后通过捕获ScriptManager的EndRequest事件,在每次 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不兼容 局部刷新jquery失效
- 解决方案•UpdatePanel 局部刷新导致jQuery失效
- Asp.net采用UpdatePanel局部刷新js失效问题
- c# ScriptManager 刷新区域 刷新后 jquery 失效 解决 UpdatePanel
- Asp.net-UpdatePanel异步刷新后JS失效的解决方法
- c#(asp.net) updatepanel 局部刷新实例收藏
- UpdatePanel控件的使用和局部刷新
- Updatepanel jquery 失效解决方案
- document.ready 与 updatepanel 害死人(Jquery插件失效,Autocomplate事件失效,Jquery事件第一次有效,单击按钮后就时效)
- updatepanel与jQuery事件失效问题的解决方法
- Jquery的datepicker 在ASP.NET UpdatePanel 中失效
- ASP.NET中使用UpdatePanel实现局部异步刷新方法和攻略(转)
- Ajax中,ModalPopup与UpdatePanel结合,实现局部刷新的登录效果 (调用cs服务)
- JQUERY的效果在UpdatePanel中控件回发后失效的解决方案
- Ajax中,ModalPopup与UpdatePanel结合,实现局部刷新的登录效果 (调用cs服务)
- 实现UpdatePanel局部刷新所需配置
- UpdatePanel局部刷新用法
- jquery 兼容 updatepanel
- c#(asp.net) updatepanel 局部刷新实例
- UpdatePanel局部刷新