Server.Transfer : Passing values from one page to another page

Some times, we want to pass values from one page to another page. There are many ways by which we can do this like: by using query string, or session variable, or Server.Transer etc.

Web Forms pages are classes in your application, and as such, you can create properties for them as you would any class. However, Web Forms pages have a very short lifetime, since they effectively exist only long enough to perform page processing. Properties on a Web Forms page therefore have limited use, since they exist only while the page is being processed. But if you transfer control from one page to another using specific techniques, the second page can still access properties on the first page.

This article shows you, how to pass values from one page to another page by using Server.Transfer() method.

Assign value to property of first page [ Form1.aspx ]

Declare Property : In first page, declare one or more read-only properties and return the property value you want to pass to the next page.

Public ReadOnly Property FirstName() As String

    Get

        Return txtFName.Value

    End Get

End Property


Public
ReadOnly Property LastName() As String

    Get

        Return txtLName.Value

    End Get 

End Property

Public ReadOnly Property Address1() As String

    Get

        Return txtAdd1.Value

    End Get 

End Property

Public ReadOnly Property Address2() As String

    Get

        Return txtAdd2.Value

    End Get 

End Property

Public ReadOnly Property UserData() As NameValueCollection

    Get

        Return Request.Form

    End Get
End Property

Call Server.Transer method to access second page.

PrivateSub btnForm2_ServerClick(ByVal sender AsObject, ByVal e As System.EventArgs) Handles btnForm2.ServerClick

    Server.Transfer("Form2.aspx")

EndSub

PrivateSub btnForm3_ServerClick(ByVal sender AsObject, ByVal e As System.EventArgs) Handles btnForm3.ServerClick

    Server.Transfer("Form3.aspx")
EndSub

To read property values from the source page in the called page.

To get the property values of the first page from the called page, create an instance variable of the source page class. You then assign to it the HTTP object (an instance of the IHttpHandler class), the object that received the original request.

1. Create a global instance variable that is typed to the class of the source page.        

Private frmSource As Form1

2. In the Page_Load handler, get the source page from the Context.Handler object (IHttpHandler interface) and assign it to the variable that you created in step 1. You must cast the handler object to the type of the source page class.

frmSource = CType(HttpContext.Current.Handler, Form1)

3. Get the property values from the source page and use them as you would any object properties.

[ Form2.aspx.vb ]

lblFName.InnerText = frmSource.FirstName

lblLName.InnerText= frmSource.LastName

lblAdd1.InnerText= frmSource.Address1

lblAdd2.InnerText= frmSource.Address2

[ Form3.aspx.vb ] 

By using NameValueCollection : The Form property of Request object returns a NameValueCollection representing a collection of form variables. You can access value of any form field by its Id like userData["txtFName"].The NameValueCollection class is a member of System.Collections.Specialized namespace.

Dim userData As NameValueCollection = frmSource.UserData

lblFName.InnerText = userData("txtFName")

lblLName.InnerText= userData("txtLName")

lblAdd1.InnerText= userData("txtAdd1")

lblAdd2.InnerText= userData("txtAdd2") 

posted @ 2008-03-27 09:36  陋室  阅读(279)  评论(0编辑  收藏  举报