Zoeken…


Levenscyclusevenementen

Hieronder volgen de levenscyclusevents van de pagina:

PreInit - PreInit is het eerste evenement in de levenscyclus van pagina's. Het controleert de eigenschap IsPostBack en bepaalt of de pagina een postback is. Het stelt de thema's en basispagina's in, maakt dynamische bedieningselementen en haalt en stelt profieleigenschappen op. Deze gebeurtenis kan worden afgehandeld door de OnPreInit-methode te overschrijven of een Page_PreInit-handler te maken.

Init - Init-gebeurtenis initialiseert de besturingseigenschap en de besturingsstructuur wordt gebouwd. Deze gebeurtenis kan worden afgehandeld door de OnInit-methode te overschrijven of een Page_Init-handler te maken.

InitComplete - Met de InitComplete-gebeurtenis kan de weergavestatus worden gevolgd. Alle bedieningselementen schakelen tracking van de weergavestatus in.

LoadViewState - Met LoadViewState-gebeurtenis kan informatie over de weergavestatus in de besturingselementen worden geladen.

LoadPostData - Tijdens deze fase wordt de inhoud van alle invoervelden die met de tag zijn gedefinieerd, verwerkt.

PreLoad - PreLoad vindt plaats voordat de postback-gegevens in de besturingselementen worden geladen. Deze gebeurtenis kan worden afgehandeld door de OnPreLoad-methode te overschrijven of een Page_PreLoad-handler te maken.

Laden - De gebeurtenis Laden wordt eerst voor de pagina verhoogd en vervolgens recursief voor alle onderliggende besturingselementen. De besturingselementen in de besturingsstructuur zijn aangemaakt. Deze gebeurtenis kan worden afgehandeld door de OnLoad-methode te overschrijven of een Page_Load-handler te maken.

LoadComplete - Het laadproces is voltooid, handlers voor besturingsgebeurtenissen worden uitgevoerd en de pagina wordt gevalideerd. Deze gebeurtenis kan worden afgehandeld door de OnLoadComplete-methode te overschrijven of door een Page_LoadComplete-handler te maken

PreRender - De PreRender-gebeurtenis vindt plaats net voordat de uitvoer wordt weergegeven. Door deze gebeurtenis af te handelen, kunnen pagina's en besturingselementen alle updates uitvoeren voordat de uitvoer wordt weergegeven.

PreRenderComplete - Omdat de PreRender-gebeurtenis recursief wordt geactiveerd voor alle onderliggende besturingselementen, zorgt deze gebeurtenis voor de voltooiing van de pre-renderingfase.

SaveStateComplete - Status van controle op de pagina wordt opgeslagen. Personalisatie, besturingsstatus en informatie over weergavestatus worden opgeslagen. De HTML-opmaak wordt gegenereerd. Deze fase kan worden afgehandeld door de Render-methode te negeren of een Page_Render-handler te maken.

UnLoad - De UnLoad-fase is de laatste fase van de levenscyclus van de pagina. Het verhoogt de UnLoad-gebeurtenis voor alle besturingselementen recursief en tot slot voor de pagina zelf. Eindschoonmaak is voltooid en alle bronnen en referenties, zoals databaseverbindingen, zijn vrijgegeven. Deze gebeurtenis kan worden afgehandeld door de OnUnLoad-methode te overschrijven of een Page_UnLoad-handler te maken.

Codevoorbeeld

using System;

namespace myProject
{
    public partial class WebForm1 : System.Web.UI.Page
    {
        public string PageSteps = string.Empty;

        //Raised after the start stage is complete and before the initialization stage begins.
        protected void Page_PreInit(object sender, EventArgs e)
        {
            PageSteps += "1 - Page_PreInit<br>";

            //Access to page Controls not available in this step
            //Label1.Text = "Step 1";
        }

        //Raised after all controls have been initialized and any skin settings have been applied.
        //The Init event of individual controls occurs before the Init event of the page.
        protected void Page_Init(object sender, EventArgs e)
        {
            PageSteps += "2 - Page_Init<br>";

            Label1.Text = "Step 2";
        }

        //Raised at the end of the page's initialization stage.
        //Only one operation takes place between the Init and InitComplete events: tracking of view state changes is turned on.
        //View state tracking enables controls to persist any values that are programmatically added to the ViewState collection.
        //Until view state tracking is turned on, any values added to view state are lost across postbacks.
        //Controls typically turn on view state tracking immediately after they raise their Init event.
        protected void Page_InitComplete(object sender, EventArgs e)
        {
            PageSteps += "3 - Page_InitComplete<br>";

            Label1.Text = "Step 3";
        }

        //Raised after the page loads view state for itself and all controls, and after it processes postback data that is included with the Request instance.
        protected override void OnPreLoad(EventArgs e)
        {
            PageSteps += "4 - OnPreLoad<br>";

            Label1.Text = "Step 4";
        }

        //The Page object calls the OnLoad method on the Page object, and then recursively does the same for each child control until the page and all controls are loaded.
        //The Load event of individual controls occurs after the Load event of the page.
        protected void Page_Load(object sender, EventArgs e)
        {
            PageSteps += "5 - Page_Load<br>";

            Label1.Text = "Step 5";
        }

        //Use these events to handle specific control events, such as a Button control's Click event or a TextBox control's TextChanged event.
        protected void btnSubmit_Click(object sender, EventArgs e)
        {
            //Step only visible on PostBack
            PageSteps += "6 - btnSubmit_Click<br>";

            Label1.Text = "Step 6";
        }

        //Raised at the end of the event-handling stage.
        protected void Page_LoadComplete(object sender, EventArgs e)
        {
            PageSteps += "7 - Page_LoadComplete<br>";

            Label1.Text = "Step 7";
        }

        //Raised after the Page object has created all controls that are required in order to render the page, including child controls of composite controls.
        //(To do this, the Page object calls EnsureChildControls for each control and for the page.)
        protected override void OnPreRender(EventArgs e)
        {
            PageSteps += "8 - OnPreRender<br>";

            Label1.Text = "Step 8";
        }

        //Raised after each data bound control whose DataSourceID property is set calls its DataBind method.
        protected override void OnPreRenderComplete(EventArgs e)
        {
            PageSteps += "9 - OnPreRenderComplete<br>";

            Label1.Text = "Step 9";
        }


        //Raised after view state and control state have been saved for the page and for all controls.
        //Any changes to the page or controls at this point affect rendering, but the changes will not be retrieved on the next postback.
        protected override void OnSaveStateComplete(EventArgs e)
        {
            PageSteps += "10 - OnSaveStateComplete<br><hr><br>";

            Label1.Text = "Step 10";
        }

        // Render
        //This is not an event; instead, at this stage of processing, the Page object calls this method on each control.
        //All ASP.NET Web server controls have a Render method that writes out the control's markup to send to the browser.

        //Raised for each control and then for the page.
        //Controls use this event to do final cleanup for specific controls, such as closing control-specific database connections
        protected void Page_UnLoad(object sender, EventArgs e)
        {
            //This last PageSteps addition will not be visible on the page
            PageSteps += "11 - Page_UnLoad<br>";

            //Access to page Controls not available in this step
            //Label1.Text = "Step 11";      
        }
    }
}

Voeg de volgende code toe aan de .aspx-pagina om de stappen in de levenscyclus te visualiseren.

<b>Page Life Cycle Visualization:</b>
<br />
<%= PageSteps %>

voer hier de afbeeldingsbeschrijving in

Meer informatie



Modified text is an extract of the original Stack Overflow Documentation
Licentie onder CC BY-SA 3.0
Niet aangesloten bij Stack Overflow