手机
当前位置:查字典教程网 >编程开发 >asp.net教程 >UpdatePanel和jQuery不兼容 局部刷新jquery失效
UpdatePanel和jQuery不兼容 局部刷新jquery失效
摘要:在做项目中发现,在使用了UpdatePanel的地方,局部刷新后,jquery失效了。后来网上一查,才发现,jquery中的ready事件会...

在做项目中发现,在使用了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失效】相关文章:

gridview调整单元格宽度的方法

asp.net中eval不能定义变量的问题的解决方法

asp.net datalist绑定数据后可以上移下移实现示例

asp.net下Request.QueryString取不到值的解决方法

使用ajax局部刷新gridview进行数据绑定示例

在DataTable中执行Select("条件")后,返回DataTable的方法

asp.net水晶报表参数字段在代码中赋值的方法

asp.net操作javascript:confirm返回值的两种方式

asp.net AJAX实现无刷新获得数据

DotNet2.0 生成网站的测试

精品推荐
分类导航