UpdatePanel和jQuery不兼容

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


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

邹琼俊

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值