服务器之家

服务器之家 > 正文

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

时间:2019-11-17 13:29     来源/作者:ASP.NET教程网

在做项目中发现,在使用了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(); 

相关文章

热门资讯

玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分
玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分 2019-06-21
男生常说24816是什么意思?女生说13579是什么意思?
男生常说24816是什么意思?女生说13579是什么意思? 2019-09-17
配置IIS网站web服务器的安全策略配置解决方案
配置IIS网站web服务器的安全策略配置解决方案 2019-05-23
Nginx服务器究竟是怎么执行PHP项目
Nginx服务器究竟是怎么执行PHP项目 2019-05-24
运维必须知道的关于云服务器的十个问题
运维必须知道的关于云服务器的十个问题 2019-05-24
返回顶部