DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> AJAX入門 >> AJAX基礎知識 >> 為AJAX請求添加客戶端事件
為AJAX請求添加客戶端事件
編輯:AJAX基礎知識     

    一、添加/刪除請求開始事件的方法:

Sys.WebForms.PageRequestManager.instance.add_beginRequest(beginRequestHandler)

Sys.WebForms.PageRequestManager.instance.remove_beginRequest(beginRequestHandler)

參數beginRequestHandler指定當請求開始之前要調用的函數。

例:

Sys.WebForms.PageRequestManager.getInstance(

).add_beginRequest(BeginRequestHandler);

function BeginRequestHandler(sender, args)

{

//添加你想做的事情

}

函數參數args是Sys.WebForms.BeginRequestEventArgs類的一個實例。

BeginRequestEventArgs類包含兩個成員

1、postBackElement 屬性,發出觸發請求的HTML對象。如: var elem = arg.get_postBackElement();

2、request 屬性,獲取當前請求的實例對象。如: var request = arg.get_request();

返回值是一個Sys.Net.WebRequest類型的實例,這裡我們對它不做過多的講述,請讀者查閱更多的資料。

    二、添加/刪除請求結束的代碼:

Sys.WebForms.PageRequestManager.instance.add_endRequest(endRequestHandler)

Sys.WebForms.PageRequestManager.instance.remove_endRequest(endRequestHandler)

參數endRequestHandler 指定當請求結束之後要調用的函數。例:

Sys.WebForms.PageRequestManager.getInstance().add_endRequest

(EndRequestHandler);

function EndRequestHandler(sender, args)

{

//你想添加的代碼

}

函數參數args是Sys.WebForms.EndRequestEventArgs類的實例。利用它可以獲取請求期間發生的異常,以及請求返回的response對象。關於這個類的詳細信息請查看其幫助,由於篇幅問題,這裡不再過多的說它。

    三、創建實例。

1、用.NET 2005創建ASP.NET AJAX-Enabled網站。

2、Default.aspx頁面的代碼如下:

<%@ Page Language="C#" AutoEventWireup="true"

CodeFile="Default.aspx.cs" Inherits="_Default"%>

<!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 id="Head1" runat="server">

<title>PageRequestManager beginRequest Example</title>

<style type="text/css">

body {

font-family: Tahoma;

}

div.AlertStyle

{

background-color: #FFC080;

top: 95%;

left: 1%;

height: 20px;

position: absolute;

visibility: hidden;

}

</style>

</head>

<body>

<form id="form1" runat="server">

<div><asp:ScriptManager ID="ScriptManager1" runat="server" />

<script type="text/javascript" language="javascript">

Sys.WebForms.PageRequestManager.getInstance(

).add_beginRequest(BeginRequestHandler);

Sys.WebForms.PageRequestManager.getInstance(

).add_endRequest(EndRequestHandler);

function BeginRequestHandler(sender, args)

{

var elem = args.get_postBackElement();

ActivateAlertDiv('visible', 'AlertDiv',

elem.value + '被單擊, 正在獲取系統時間');

}

function EndRequestHandler(sender, args)

{

ActivateAlertDiv('hidden', 'AlertDiv', '');

}

function ActivateAlertDiv(visstring, elem, msg)

{

var adiv = $get(elem);

adiv.style.visibility = visstring;

adiv.innerHTML = msg;

}

</script>

<asp:UpdatePanel ID="UpdatePanel1"

UpdateMode="Conditional" runat="Server">

<ContentTemplate>

<asp:Panel ID="Panel1" runat="server"

GroupingText="Update Panel">

    最後一次更新時間:

<%= DateTime.Now.ToString()%>.

<br />

<asp:Button runat="server" ID="Button1"

Text="第一個按鈕" OnClick="ProcessClick_Handler" />

<asp:Button runat="server" ID="Button2"

Text="第二個按鈕" OnClick="ProcessClick_Handler" />

</asp:Panel>

</ContentTemplate>

</asp:UpdatePanel>

<div id="AlertDiv" class="AlertStyle">

</div></div></form></body>

</html>

3、Default.aspx.cs代碼如下:

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 ProcessClick_Handler(object sender, EventArgs e)

{

System.Threading.Thread.Sleep(2000);

}}

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