• 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();
            }


  • 相关阅读:
    2016/05/16 thinkphp3.2.2 验证码使用
    2016/05/16 UEditor 文本编辑器 使用教程与使用方法
    2016/05/15 ThinkPHP3.2.2 表单自动验证实例 验证规则的数组 直接写在相应的控制器里
    DropzoneJS 使用指南
    MVC设计模式
    Smarty 配置文件的读取
    会话控制
    JS中的call和apply
    CSS选择器
    XML
  • 原文地址:https://www.cnblogs.com/james1207/p/3310780.html
Copyright © 2020-2023  润新知