欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

ASP.NET 2.0页面框架的几处变化

程序员文章站 2022-03-21 23:30:15
新增的页面事件: 在asp.net 2.0中,一个asp.net页面的生命周期主要为(红色字体表示asp.n...

新增的页面事件:
在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的情况下还可以对控件状态进行读写操作。
增加对页面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", "*s");
}
</script>

其运行结果为:
<html>
<head> <title>untitled page</title>
<meta name="author" content="*s" />
</head>
定义表单中的默认按钮:
在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>
设置焦点:
现在假设为textbox1控件设置焦点,在asp.net 2.0中可以这样实现:
this.textbox1.focus(); 或 this.setfocus(this.textbox1); 即可为textbox1控件设置焦点。
如果打算也为表单设置个默认焦点控件,让光标默认停留在textbox1上:
<form runat="server" defaultfocus="textbox1">
跨页面数据发送:
如果你需要多个页面发送数据到同一个表单程序进行处理,或者数据在多个页面之间传输处理的话,你就可以使用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>