Welcome 微信登录
编程资源 图片资源库 蚂蚁家优选

首页 / 网页编程 / ASP.NET / ASP.NET自定义控件从入门到精通3

ASP.NET自定义控件从入门到精通32011-04-17 博客园 hongbo05213 状态管理和Style类

3.1 状态管理

在上一节中,我们成功的开发了一个具有设计器属性的注册控件。现在我们来学习对我们 的注册控件进行状态管理。

首先我们回顾一下ASP.NET的页面的生命周期,如图3.1.1所示:

图3.1.1 ASP.NET 页面的生命周期

这里我们发现,任何页面只要发生了回传就一定会被服务器销毁(除了像Ajax一样的异步 回传)。那么就出现了一个问题,我们的自定义控件上所有的属性都会被销毁,而服务器端 将无法获取自定义控件的值。

所有的Web页面都是无法保持状态的,我们需要使用ViewState来保持页面的状态。 ViewState是属于当前页面的,不会混淆。修改RegisterControl中的代码,代码如下所示:

namespace RegisterControl

{

[DefaultProperty("UserName")]

[ToolboxData("<{0}:RegisterControl runat="server" UserName="请输入用户名" />")]

public class RegisterControl : WebControl

{

[Browsable(true)]

[Description("读写属性,获取或设定用户名密码框中的值")]

[Category("杂项")]

public virtual string UserPwd

{

get { return this.ViewState["UserPwd"].ToString(); }

set { this.ViewState["UserPwd"] = value; }

}

[Browsable(true)]

[Description("读写属性,获取或设定用户名文本框中的值")]

[DefaultValue("请输入用户名")]

[Category("杂项")]

public virtual string UserName

{

get { return this.ViewState["UserName"]; }

set { this.ViewState["UserName"] = value; }

}

protected override void Render(HtmlTextWriter writer)

{

writer.Write(string.Format(@" <table> <caption>用户注册 </caption> <tbody> <tr> <td>用户名:</td> <td> <input name="txtUserName" type="text" id="txtUserName" value="{0}" onfocus="this.select()" /> </td> </tr> <tr> <td>密 &nbsp;&nbsp;码:</td> <td> <input name="txtPassword" type="password" id="txtPassword" value="{1}" /> </td> </tr> <tr> <td>确认密码:</td> <td> <input name="txtSecPassword" type="password" id="txtSecPassword" /> </td> </tr> <tr> <td colspan="2"> <input type="submit" name="btnRegister" value="注册" id="btnRegister" /> &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <input type="reset" id="btnReset" value="重置" /> </td> </tr> </tbody> </table> ",this.UserName,this.UserPwd));

}

}

}

注意:在ViewState中存储值,需要注意以下一些方面:

1.ViewState中存储的对象必须可以被直接序列化。而且特别需要注意的是,ViewState可 针对特定类型转换进行优化,基础数据类型都会被优化。如果存储自定义类型的对象,最好 重写GetHash()、ToString()等方法,并且自定义类型转换器。

2.存储在ViewState中的信息必须简短,减轻页面压力。