UpdatePanel和jQuery不兼容 局部刷新jquery失效
程序员文章站
2024-03-01 09:45:04
在做项目中发现,在使用了updatepanel的地方,局部刷新后,jquery失效了。 后来网上一查,才发现,jquery中的ready事件会在dom完全加载后运行一次,而...
在做项目中发现,在使用了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();
}
后来网上一查,才发现,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();
}
上一篇: java异常机制分析