0

1 つのページで ajax UpdatePanel と ICallbackEventHandler を使用したいと考えています。それぞれがページの個々の部分を処理し、それぞれに関連していません。

UpdatePanel を削除すると、ICallbackEventHandler が機能します。ICallbackEventHandler を削除すると、更新パネルは機能しますが、完全には機能しません:(

デフォルト.aspx

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Default.aspx.cs" Inherits="WebApplication1._Default"
EnableEventValidation="false" %>
   <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.5.1/jquery.min.js"></script>
</head>
<body>
<script type="text/ecmascript">
    function BootX() {
        XUpdate();
    }

    function XUpdate() {
        X_CallServer("", "");
    }

    function X_ReceiveServerData(rValue) {
        $("#a").html(rValue);
    }
</script>
<form id="form1" runat="server">
<div id="a">
</div>
<asp:ScriptManager runat="server" ID="ScriptManager1" />
<div>
    <asp:Timer ID="Timer1" runat="server" Interval="100" OnTick="Timer1_Tick">
    </asp:Timer>
    <asp:UpdatePanel runat="server" ID="UpdatePanel1" UpdateMode="Conditional">
        <ContentTemplate>
            <asp:DropDownList runat="server" ID="ddl">
            </asp:DropDownList>
        </ContentTemplate>
    </asp:UpdatePanel>
</div>
</form>
<script type="text/ecmascript">
    BootX();
</script>
</body>
</html>

コードビハインド:

public partial class _Default : System.Web.UI.Page, ICallbackEventHandler
{
    protected void Page_Load(object sender, EventArgs e)
    {
        String cbReference = Page.ClientScript.GetCallbackEventReference(this, "arg", "X_ReceiveServerData", "context", true);
        String callbackScript = string.Format("function X_CallServer(arg, context)" + "{{ {0} ;}}", cbReference);
        Page.ClientScript.RegisterClientScriptBlock(this.GetType(), "X_CallServer", callbackScript, true);
        ScriptManager1.RegisterAsyncPostBackControl(Timer1);
    }

    private string result = "";
    public void RaiseCallbackEvent(string eventArgument)
    {
        // pretending some time consuming work
        for (int i = 0; i < 1000000; i++) for (int j = 0; j < 100; j++) ;
        result = "aaaaaaaaaaaaaaaaaaaaaaaaaaaa";
    }

    public string GetCallbackResult()
    {
        return result;
    }

    protected void Timer1_Tick(object sender, EventArgs e)
    {
        UpdatePanel1.Update();
        Timer1.Enabled = false;

        // pretending some time consuming work
        for (int i = 0; i < 1000000; i++) for (int j = 0; j < 1000; j++) ;
        ddl.Items.Add("Item 1");
        ddl.Items.Add("Item 2");
        ddl.Items.Add("Item 3");
    }
}

上記のコードは単なる概念です。1 つのページで ICallbackEventhandler を使用する 5 つのコントロールが既にあり、それらは完全に機能しています。updatepanel を使用しているページに新しいコントロールを 1 つ追加する必要があり、他のすべての「ICallbackEventhandler」コントロールが壊れました。

4

1 に答える 1

1

数時間後、解決策が見つかりました。

それ以外の

<script type="text/ecmascript">    BootX();</script>

使った

function pageLoad(sender, args) {setTimeout("BootX()", 25); }

そしてそれは働いています。解決策は非常に簡単でした:) UpdatePanel はポストバックを使用し、ポストバックが行われるたびに pageLoad メソッドが呼び出され、ここでコールバック関数を呼び出します。

于 2011-06-15T20:36:34.780 に答える