4

我正在使用更新面板进行异步回发。在异步回发 jQuery 功能不起作用之后。我正在使用 jQuery 对 UpdatePanel 内的 html 表格单元格连接一些 mousedown mouseenter 效果。事件绑定在 $(document).ready

     <script type="text/javascript">

                $(function ()



     {
    $(".csstablelisttd").mousedown(function (e)
                        {
    //mouse down code
    });
 $(".csstablelisttd").mouseenter(function (e)
                        {
    //mouse entercode
    });
                        $("#contentPlaceHolderMain_btnFix").click(function (e)
                        {alert("Alert");//here alert is generate two times an then postback occurs
                           //btn click code
                        }
                    }

            </script>

    <asp:UpdatePanel ID="updatePanelTableAppointment" runat="server">
                            <ContentTemplate>
         <table id="table" runat="server">
             //table data
            </table>

                        </ContentTemplate><Triggers>
                            <asp:AsyncPostBackTrigger ControlID="btnFix" EventName="Click" />
                        </Triggers>
                    </asp:UpdatePanel>
4

2 回答 2

4

asp:UpdatePanel用服务器返回的结果替换内容。这意味着以前的所有挂钩事件在回发后都将不起作用。

改为使用jQuery.on()

例如:

<script type="text/javascript">
$(function () {

    $("#table").on("mousedown mouseenter", ".csstablelisttd", function (e) {
        //mouse down AND mouse enter code
    });

    $("#contentPlaceHolderMain_btnFix").on("click", function (e) {
        alert("Alert");//here alert is generate two times an then postback occurs
        //btn click code
    });
});
</script>

注意:如果您的鼠标按下和鼠标输入代码不同,请将它们分开。

对包含在UpdatePanel.

于 2012-07-03T10:33:09.653 回答
2

您必须为 Toolkit 提供的 ajax endRequest 添加事件处理程序。在这里阅读更多

添加在页面加载时执行的 Javascript 块。

Sys.WebForms.PageRequestManager.getInstance().add_endRequest(endRequestHandle);

function endRequestHandle(sender, Args)
{
     alert("After ajax call");
}
于 2012-07-03T10:35:05.113 回答