天天@BLOG

脖子越来越疼,脑袋越来越钝
  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

ASP.NET 2.0页面框架的几点新功能

Posted on 2007-01-11 14:29  天天在线  阅读(333)  评论(0编辑  收藏  举报
  1. 新增的页面事件
    在ASP.NET 2.0中,一个ASP.NET页面的生命周期主要为(红色字体表示ASP.NET 2.0新增加的阶段页面事件):客户端请求页面—》预初始化(OnPreInit)—》初始化(OnInit)—》完成初始化(OnInitComplete)—》载入ViewState(LoadViewState)—》处理回送数据(IPostBackDataHandler)—》Page_OnPreLoad—》Page_OnLoad—》回发更改通知(RaisePostDataChangedEvent)—》处理回发事件(RaisePostBackEvent)—》Page_OnLoadComplete—》预呈现(OnPreRender)—》完成预呈现(OnPreRenderComplete)—》保存ControlState(SaveControlState)—》保存ViewState(SaveViewState)—》呈现(Render)—》Page_UnLoad。
    • OnPreInit:在初始化页面OnInit事件前触发。在这个阶段里,可以进行定义站点主题(Theme)或加载站点个性化所需要的数据信息等操作。
    • OnInitComplete:完成初始化页面OnInit事件后触发。
    • OnPreLoad:在加载页面OnLoad事件前触发。
    • OnLoadComplete:完成页面加载OnLoad事件后触发。
    • OnPreRenderComplete:在完成预呈现OnPreRender事件后触发。这是完成页面呈现的最后一道关卡,在此之后,页面将无法再进行任何呈现上的改动。
    • SaveControlState:保存控件状态ControlState。ControlState是ASP.NET2.0控件新增的一个属性,类似ViewState作用,但它们区别在于ControlState用于保存更加重要的控件状态信息,以保证在禁用ViewState的情况下还可以对控件状态进行读写操作。
  2. 增加对页面Header的控制:
    System.Web.UI.Page类新增加了Header属性,用于对HTML页面头区域里数据的操作。通过对Header属性的跟踪,可以发现,Header属性保存着一个实现IPageHeader接口的对象(该对象有LinkedStyleSheets、Metadata、StyleSheet和Title四个属性),实际上正是通过这个对象实现对HTML页面头区域里数据的操作的。例如:
    <script runat="server">
    void Page_Load(object sender, System.EventArgs e)
    {
       
    this.Header.Metadata.Add("author", "brooks");
    }
    </script>
    其运行结果为:
    <html>
    <head> <title>Untitled Page</title>
       
    <meta name="author" content="brooks" />
    </head>
  3. 定义表单中的默认按钮:
    在ASP.NET1.0中,我就为了设置表单中的默认按钮而一筹莫展。幸好ASP.NET2.0把这个功能补上了,现在可以非常方便的设置表单中的默认按钮了。
    <%@ page language="C#" %>
    <script runat="server">
    void Button1_Click(object sender, System.EventArgs e)
    {
       
    this.LB_Message.Text = "You clicked button1";
    }
    </script>
    <html>
    <head runat="server">
       
    <title>Untitled Page</title>
    </head>
    <body>
       
    <form runat="server" defaultbutton="Button1">
           
    <asp:textbox id="Textbox1" runat="server"></asp:textbox>
           
    <asp:button id="Button1" runat="server" text="Button" onclick="Button1_Click" />
           
    <asp:label id="LB_Message" runat="server"></asp:label>
       
    </form>
    </body>
    </html>
  4. 设置焦点
    现在假设为TextBox1控件设置焦点,在ASP.NET 2.0中可以这样实现:
    this.Textbox1.Focus();  this.SetFocus(this.Textbox1); 即可为TextBox1控件设置焦点。
    如果打算也为表单设置个默认焦点控件,让光标默认停留在TextBox1上:
    <form runat="server" defaultfocus="TextBox1">
  5. 跨页面数据发送
    如果你需要多个页面发送数据到同一个表单程序进行处理,或者数据在多个页面之间传输处理的话,你就可以使用ASP.NET 2.0这个新特性。例如,我打算把Default.aspx页里TextBox1里的文本数据发送到Default2.aspx页面进行处理:
    Default.aspx页:
    <%@ Page Language="C#" %>
    <script runat="server">
       
    void Button2_Click(object sender, EventArgs e)
        {
            Label1.Text
    = "Hi," + TextBox1.Text + ". This is Default.aspx";
        }
    </script>

    <html xmlns="http://www.w3.org/1999/xhtml" >
    <head runat="server">
       
    <title>Untitled Page</title>
    </head>
    <body>
       
    <form id="form1" runat="server">
           
    <asp:TextBox ID="TextBox1" Runat="server"></asp:TextBox>
           
    <asp:Button ID="Button1" Runat="server" Text="PostToAnotherPage" PostBackUrl="~/Default2.aspx" />
           
    <asp:Button ID="Button2" Runat="server" Text="PostToSelf" OnClick="Button2_Click" />
           
    <br />
           
    <asp:Label ID="Label1" Runat="server" Text="Label"></asp:Label>
       
    </form>
    </body>
    </html>
    Default2.aspx页:
    <%@ Page Language="C#" %>
    <script runat="server">
       
    void Page_Load(object sender, System.EventArgs e)
        {
            TextBox textBox1
    = (TextBox)PreviousPage.FindControl("TextBox1");
           
    this.Label1.Text = "Hi," + textBox1.Text + ". This is Default2.aspx!";
        }
    </script>
    <html xmlns="http://www.w3.org/1999/xhtml" >
    <head runat="server">
       
    <title>Untitled Page</title>
    </head>
    <body>
       
    <form id="form1" runat="server">
       
    <asp:label id="Label1" runat="server"></asp:label>
       
    </form>
    </body>
    </html>
  6. asp.net 2.0中的defaultulr属性

    在asp.net 2.0中,在web.config文件中,新增加了defaulturl属性,这个可以在用户登陆后,转向指定的一个页面。当在.net 2.0中使用RedirectFromLoginPage() 方法时,将自动跳转到defaulturl指定的地址,下面是个例子
       <authentication mode="Forms">
      <forms loginUrl="member_login.aspx"
             defaultUrl="index.aspx" />
    </authentication>

    1、提交后的回发时能自动进入上次的当前位置

    例如,如果数据项导致大型页回发,则最终用户需要将页滚动到此前正在编辑它们的位置,才能继续。页开发人员通过以下方法可以简单地标记窗体,以维持滚动位置:在 @Page 指令中将 MaintainScrollPositionOnPostBack 属性设置为 true,或在 Web.config 中进行此设置,以应用于应用程序中的所有页。

    2、Button 控件的 OnClientClick 属性允许您在此按钮被单击时以编程方式运行客户端脚本。该按钮呈现客户端 onclick 属性以及按钮自身的 Javascript。

    3、用于控件的一个令人惊喜的新功能是“客户端回调”,该功能允许控件向服务器执行带外请求以获取附加数据,而不发送整页。此功能依赖于用于回调处理(通常通过 XMLHTTP)的浏览器支持,该支持由 SupportsClientCallbacks 在浏览器功能中指定。

    其实一般的无刷新页面就可以使用客户端回调来实现,只有复杂的才需要使用AJAX等

    <%@ Page Language="C#" AutoEventWireup="true" EnableEventValidation="false" CodeFile="CallBackEventHandler_cs.aspx.cs" Inherits="CallBackEventHandler_cs" %>

    <!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>Client CallBack</title>
    </head>
    <body>
    <form id="Form1" runat="server">

       
    <h3>Cascading DropDownLists Using ICallBackEventHandler</h3>
       
    <asp:DropDownList ID="ParentDropDown"
        onchange
    ="GetChildren(this.options[this.selectedIndex].value, 'ddl');"   
        Runat
    ="server">
         
    <asp:ListItem Text="Item 1" />
         
    <asp:ListItem Text="Item 2" />
         
    <asp:ListItem Text="Item 3" />
       
    </asp:DropDownList>
       
    <asp:DropDownList ID="ChildDropDown" AutoPostBack="true" style="visibility:hidden" Runat="Server">
        
    <asp:ListItem Text="Child Item" />
       
    </asp:DropDownList>
       
    <br /><br />
       
    <asp:Label ID="Label1" runat="server"/>

       
    <script type="text/javascript">

       function ClientCallback(result, context)
    {

          var childDropDown 
    = document.forms[0].elements['<%=ChildDropDown.UniqueID%>'];

          
    if (!childDropDown){
             
    return;
          }


          childDropDown.length 
    = 0;

          
    if (!result){
              
    return;
          }

          
          var rows 
    = result.split('|'); 
          
    for (var i = 0; i < rows.length; ++i){
             var option 
    = document.createElement("OPTION");
             option.value 
    = rows[i];
             option.innerHTML 
    = rows[i];     
             childDropDown.appendChild(option);
          }

          
          childDropDown.style.visibility 
    = "visible";
       }


       function ClientCallbackError(result, context)
    {
          alert(result);
       }


       
    </script>

    </form>
    </body>

    </html>

    //-----------------------------------------------------------------------
    //  This file is part of the Microsoft .NET SDK Code Samples.
    // 
    //  Copyright (C) Microsoft Corporation.  All rights reserved.
    // 
    //This source code is intended only as a supplement to Microsoft
    //Development Tools and/or on-line documentation.  See these other
    //materials for detailed information regarding Microsoft code samples.
    // 
    //THIS CODE AND INFORMATION ARE PROVIDED AS IS WITHOUT WARRANTY OF ANY
    //KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
    //IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A
    //PARTICULAR PURPOSE.
    //-----------------------------------------------------------------------

    using System;
    using System.Web.UI;

    public partial class CallBackEventHandler_cs : System.Web.UI.Page, ICallbackEventHandler
    {
        
    private string _callbackResult;

        
    private void Page_Load(object source, EventArgs e)
        
    {
            String callBack 
    = Page.ClientScript.GetCallbackEventReference(this"arg""ClientCallback""context""ClientCallbackError"false);
            String clientFunction 
    = "function GetChildren(arg, context){ " + callBack + "; }";
            Page.ClientScript.RegisterClientScriptBlock(
    this.GetType(), "GetChildren", clientFunction, true);

            
    if (Page.IsPostBack && !Page.IsCallback)
            
    {
                Label1.Text 
    = "You Selected: " + Request.Form["ParentDropDown"+ "" + Request.Form["ChildDropDown"];
            }

        }


        
    public string GetCallbackResult()
        
    {        
            
    return _callbackResult;
        }


        
    public void RaiseCallbackEvent(string eventArgument)
        
    {
            
    switch (eventArgument)
            
    {
                
    case "Item 1":
                    _callbackResult 
    = "One|Two|Three";
                    
    break;
                
    case "Item 2":
                    _callbackResult 
    = "Four|Five|Six";
                    
    break;
                
    case "Item 3":
                    _callbackResult 
    = "Seven|Eight|Nine";
                    
    break;
                
    default:
                    _callbackResult 
    = "";
                    
    break;
            }

        }


    }

    引用:http://blog.joycode.com/liuhuimiao/archive/2004/09/09/32921.aspx  
@忙碌,不代表有效率;方法,远胜于苦干