主页 > 知识库 > UpdatePanel和jQuery不兼容 局部刷新jquery失效

UpdatePanel和jQuery不兼容 局部刷新jquery失效

热门标签:外呼系统费用一年 外呼系统代理品牌 怎么给超市做地图标注入驻店 十堰正规电销机器人系统 巫师3为什么地图标注的财宝没有 手机地图标注如何删除 宁波自动外呼系统代理 世纪佳缘地图标注怎么去掉 办理400电话证件
在做项目中发现,在使用了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();
}
您可能感兴趣的文章:
  • vs.net控件updatePanel实现无刷新的方法
  • asp.net UpdatePanel实现无刷新上传图片
  • 使用updatepanel局部刷新实现注册时对用户名的检测示例

标签:通辽 景德镇 泰州 山西 牡丹江 嘉兴 平凉 天门

巨人网络通讯声明:本文标题《UpdatePanel和jQuery不兼容 局部刷新jquery失效》,本文关键词  UpdatePanel,和,jQuery,不兼容,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《UpdatePanel和jQuery不兼容 局部刷新jquery失效》相关的同类信息!
  • 本页收集关于UpdatePanel和jQuery不兼容 局部刷新jquery失效的相关信息资讯供网民参考!
  • 推荐文章