1. En esta unidad tratamos el ciclo de vida de la página web, gracias a que esta contiene todos los
estados o fases por la que pasa, y nos muestra desde el inicio hasta el fina de su desarrollo, nos
ayuda a que se detecten los errores mas rápidos, del mismo modo mejora la calidad de nuestra
pagina, visualizamos lo plazos de implementación y sus costos.
Fase Descripción
La solicitud de página se produce antes de que comience el ciclo de vida de la
página. Cuando un usuario solicita la página, ASP.NET determina si ésta se
Solicitud de página debe analizar y compilar (a fin de que comience el ciclo de vida de la página) o
si se puede enviar una versión en caché de la página como respuesta sin
ejecutar la página.
En el paso de inicio, se establecen las propiedades de la página, como Request
y Response. En esta fase, la página también determina si la solicitud es una
Inicio devolución de datos o una nueva solicitud, y establece la propiedad
IsPostBack. Además, durante esta fase se establece la propiedad UICulture de
la página.
Durante la inicialización de la página, los controles incluidos en ella están
disponibles y se establece la propiedad UniqueID de cada uno de ellos.
Inicialización de Además, se aplican los temas correspondientes a la página. Si la solicitud
página actual es una devolución de datos, los datos de devolución aún no se han
cargado y los valores de las propiedades del control no se han restaurado a
los valores del estado de vista.
Durante la carga, si la solicitud actual es una devolución de datos, las
Carga propiedades del control se cargan con información recuperada del estado de
vista y del estado del control.
Durante la validación, se llama al método Validate de todos los controles de
Validación validación, que establece la propiedad IsValid de cada uno de los controles de
validación y de la página.
Control de eventos
Si la solicitud es una devolución de datos, se llama a los controladores de
de devolución de
eventos.
datos
Antes de representar los datos, se guarda el estado de vista de la página y de
todos los controles. Durante la fase de representación, la página llama al
Representación
método Render para cada control, proporcionando un escritor de texto que
escribe su resultado en OutputStream de la propiedad Response de la página.
Se llama a la descarga cuando la página se ha representado completamente,
se ha enviado al cliente y está lista para ser descartada. Llegado este
Descarga
momento, se descargan las propiedades de la página, como Response y
Request, y se llevan a cabo las operaciones de limpieza correspondientes.
2. Eventos del ciclo de vida
Dentro de cada fase del ciclo de vida de una página, ésta produce eventos que puede controlar
para ejecutar su propio código. En los eventos de control, el controlador de sucesos se debe
enlazar al evento, bien mediante declaración utilizando atributos como onclick o bien en el código.
Las páginas también admiten la conexión automática de eventos, lo que significa que ASP.NET
busca métodos con nombres determinados y los ejecuta automáticamente cuando se provocan
ciertos eventos. Si el atributo AutoEventWireup de la directiva @ Page se establece en true (o si
no está definido, ya que de forma predeterminada es true), los eventos de página se enlazan de
forma automática a los métodos que utilizan la convención de nomenclatura Page_evento, por
ejemplo Page_Load y Page_Init. Para obtener más información sobre la conexión automática de
eventos, consulte Modelo de eventos de control de servidor Web ASP.NET.
En la tabla siguiente se muestran los eventos del ciclo de vida de la página que se utilizan con más
frecuencia. Hay más eventos de los que se muestran, pero éstos no se utilizan en la mayoría de los
escenarios de procesamiento de páginas. Los utilizan fundamentalmente los controles de servidor
de la página Web ASP.NET para sus propias tareas de inicialización y representación. Si desea
escribir sus propios controles de servidor ASP.NET, necesitará saber más sobre estas fases. Para
obtener información sobre cómo crear controles personalizados, consulte Desarrollar controles de
servidor ASP.NET personalizados.
Evento de página Uso típico
PreInit Utilice este evento para lo siguiente:
• Examine la propiedad IsPostBack para determinar si es la primera vez
que se procesa la página.
• Crear o volver a crear controles dinámicos.
• Establecer una página maestra de forma dinámica.
• Establecer la propiedad Theme de forma dinámica.
• Leer o establecer los valores de las propiedades de perfil.
•
3. Nota
Si la solicitud es una devolución de datos, los valores de los controles todavía
no se han restaurado del estado de vista. Si establece una propiedad de un
control en esta fase, es posible que su valor se sobrescriba en el evento
siguiente.
Se provoca cuanto todos los controles se han inicializado y se aplicado la
Init configuración de máscara. Utilice este evento para leer o inicializar las
propiedades del control.
Lo provoca el objeto Page. Utilice este evento para tareas de procesamiento
InitComplete
que requieran que todo el proceso de inicialización haya finalizado.
Utilice este evento si necesita realizar tareas de procesamiento en su página o
control antes de que se provoque el evento Load.
PreLoad
Después de que Page provoca este evento, carga su estado de vista y el de
todos los controles y, después, procesa todos los datos de devolución incluidos
con la instancia de Request.
Page llama al método del evento OnLoad en Page, realiza la misma operación
de forma recursiva para cada control secundario, los cuales realizan la misma
operación para cada uno de sus controles secundarios hasta que se cargan la
Load página y todos los controles.
Utilice el método del evento OnLoad para establecer las propiedades de los
controles y establecer las conexiones a bases de datos.
Eventos de control Utilice estos eventos para controlar eventos de control específicos, como un
evento Click del control Button o un evento TextChanged del control TextBox.
4. Nota
En una solicitud de devolución de datos, si la página contiene controles de
validación, compruebe la propiedad IsValid de Page y de cada uno de los
controles de validación antes de realizar cualquier procesamiento.
Utilice este evento para las tareas que requieran que se carguen todos los
LoadComplete
demás controles en la página.
Antes de que se produzca este evento:
• El objeto Page llama a EnsureChildControls para cada control y para la
página.
• Cada control enlazado a datos cuya propiedad DataSourceID esté
establecida llama a su método DataBind. Para obtener más
PreRender
información, vea Eventos de enlace de datos de controles enlazados a
datos más adelante.
El evento PreRender se produce para cada control de la página. Utilice el
evento para realizar cambios finales en el contenido de la página o en sus
controles.
Antes de que se produzca este evento, ViewState se ha guardado para la
página y para todos los controles. Se omitirán todos los cambios que se
realicen en este momento en la página o en los controles.
SaveStateComplete
Utilice este evento para realizar tareas que requieran guardar el estado de
vista, pero que no efectúen cambios en los controles.
Render Éste no es un evento; en esta fase del procesamiento, el objeto Page llama a
este método en cada control. Todos los controles de servidor Web de ASP.NET
tienen un método Render que escribe el marcado del control que se envía al
explorador.
Si crea un control personalizado, normalmente reemplazará este método para
generar el marcado del control. Sin embargo, si el control personalizado sólo
incorpora controles de servidor Web de ASP.NET estándar y ningún marcado
5. personalizado, no necesita reemplazar el método Render. Para obtener más
información, consulte Desarrollar controles de servidor ASP.NET
personalizados.
Un control de usuario (un archivo .ascx) incorpora automáticamente la
representación, por lo que no necesita representar explícitamente el control
en el código.
Este evento se produce para cada control y después para la página. En los
controles, utilice este evento para realizar tareas finales de limpieza en
controles específicos, como cerrar las conexiones a bases de datos específicas
del control.
Para la propia página, utilice este evento para hacer un último trabajo de
limpieza, como cerrar archivos abiertos y conexiones a bases de datos, finalizar
el registro u otras tareas específicas de la solicitud.
Nota
Unload
Durante la fase de descarga, la página y sus controles ya se han representado,
por lo que no se podrán realizar más cambios en la secuencia de respuesta. Si
intenta llamar a un método, como Response.Write, la página producirá una
excepción.