欢迎光临
我们一直在努力

ASP.NET 2.0页面框架的几处变化-ASP教程,ASP应用

建站超值云服务器,限时71元/月

新增的页面事件:

在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>

赞(0)
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » ASP.NET 2.0页面框架的几处变化-ASP教程,ASP应用
分享到: 更多 (0)