3 状态管理和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>密 码:</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'' /> <input type=''reset'' id=''btnReset'' value=''重置'' /> </td> </tr> </tbody> </table> ",this.UserName,this.UserPwd));
}
}
}
注意:在ViewState中存储值,需要注意以下一些方面:
1.ViewState中存储的对象必须可以被直接序列化。而且特别需要注意的是,ViewState可 针对特定类型转换进行优化,基础数据类型都会被优化。如果存储自定义类型的对象,最好 重写GetHash()、ToString()等方法,并且自定义类型转换器。
2.存储在ViewState中的信息必须简短,减轻页面压力。 |