新增的页面事件:
在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", "brooks");
}
</script>
其运行结果为:
<html>
<head> <title>untitled page</title>
<meta name="author" content="brooks" />
</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>