DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> AJAX入門 >> AJAX詳解 >> 注冊起動腳本,ASP.NET AJAX的一項重要功能!
注冊起動腳本,ASP.NET AJAX的一項重要功能!
編輯:AJAX詳解     
  最近的項目中一直在使用Atlas July CTP,自從Atlas正式更名後,連續推出了Beta和Beta2兩個版本,但是我一直在觀望,原因就是Beta版本不穩定而且升級太麻煩了。一日偶然看到了楊丹的這篇隨筆,突然發現原來ScriptManager可以注冊在客戶端部分刷新的UpdatePanel中注冊啟動後執行的javascript!這可是困擾了我很長時間的一個問題!這樣不但可以在使用UpdatePanel的情況下使用Javascript彈出對話框,也可以在開發使用Javascript腳本的服務器控件的時候,使控件的起動腳本得以執行,這樣原來的和UpdatePanel不兼容的控件可以很容易的改為AJax enabled^_^。
    不過,令人不解的是不知道處於什麼考慮,RegisterStartupScript函數竟然實現為了類的靜態函數,可是沒有ScriptManager的UpdatePanel更本不能執行啊,這樣還需要多打幾個字!另外,需要注意的是第一個參數是UpdatePanel的實例,如果在頁面中有多個UpdatePanel,如果每個UpdatePanel的UpdateMode都是“always”[默認值]的話,那麼你使用那個UpdatePanel的實例作為參數都可以;如果每個UpdaePanel的UpdateMode=conditional,那麼你必須使用正在更新的那個UpdatePanel作為參數,這樣腳本才能起作用。下面是我作的一個簡單的示例:
頁面標記
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.ASPx.cs" Inherits="_Default" %>

<!DOCTYPE Html PUBLIC "-//W3C//DTD XHtml 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xHtml11.dtd">
<html XMLns="http://www.w3.org/1999/xHtml">
<head runat="server">
    <title>Untitled Page</title>
</head>
<body>
    <form id="form1" runat="server">
            <ASP:ScriptManager ID="ScriptManager1" EnablePartialRendering="true" runat="server">
            </ASP:ScriptManager>
            <br />
            <ASP:updatepanel id="UpdatePanel1" UpdateMode="conditional"  runat="server"><ContentTemplate>
<asp:TextBox id="TextBox1" runat="server" ></asp:TextBox> <asp:LinkButton id="LinkButton1" runat="server" >LinkButton</ASP:LinkButton>
</ContentTemplate>
                <Triggers>
                    <ASP:AsyncPostBackTrigger ControlID="LinkButton1" />   
                    </Triggers>
</ASP:updatepanel>
            <ASP:UpdatePanel ID="UpdatePanel2" RenderMode="block"  UpdateMode="always"  runat="server">
                <ContentTemplate>
                    <asp:TextBox ID="TextBox2" runat="server"></ASP:TextBox>
                    <asp:LinkButton ID="LinkButton2" runat="server" >LinkButton</ASP:LinkButton>
                </ContentTemplate>
            </ASP:UpdatePanel>
            <br />
        <div>
                    <br />
                    <ASP:updateprogress id="UpdateProgress1" runat="server"><ProgressTemplate>
Please waiting, retrIEving data from server
</ProgressTemplate>
</ASP:updateprogress>
                     </div>
    </form>
</body>
</Html>

代碼
using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;

public partial class _Default : System.Web.UI.Page
{
  protected void Page_Load(object sender, EventArgs e)
  {
       
  }
    protected void LinkButton1_Click(object sender, EventArgs e)
    {
        System.Threading.Thread.Sleep(1000);
        TextBox1.Text = DateTime.Now.ToLongTimeString();
        TextBox2.Text = TextBox1.Text;
        string JS = "alert('ok button1 clicked!')";
        Microsoft.Web.UI.ScriptManager.RegisterStartupScript(UpdatePanel2, this.GetType(), "btn1clicked", JS, true);
    }
    protected void LinkButton2_Click(object sender, EventArgs e)
    {
        System.Threading.Thread.Sleep(900);
        TextBox2.Text = DateTime.Now.ToLongTimeString();
        TextBox1.Text = TextBox2.Text;
        string JS = "alert('ok button 2 clicked!')";
   
        Microsoft.Web.UI.ScriptManager.RegisterStartupScript(UpdatePanel2, this.GetType(), "btn2clicked", JS, true);
   
    }
}    BTW,我在使用時發現一個問題,不知道是個Bug還是我使用不當,我在調試中發現UpdatePanel.IsInPartialRendering的值始終是false!希望有高人指點一下:)。

http://www.cnblogs.com/dajianshi/archive/2006/11/20/565524.Html

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved