ASP.NET常用小技巧

2019-05-23 01:52:01丽君

将数据验证任务从服务器端迁移到客户端的过程促使了JavaScript的产生,这也是我们沿用至今的一种方式。但只有在保证客户端JavaScript正常运行的前提下,这种方式才能发挥其作用。不幸的是,总有一些例外,比如浏览器不支持JavaScript,或者用户刻意关闭了浏览器的JavaScript功能,这就导致了第一重防护失效。比较保险的做法是加入第二重防护,即对用户提交的数据进行服务器端验证,但这无疑将增加开发者的工作量。 
ASP.NET 2.0提供了一系列表单数据验证控件,可以非常轻松的完成客户端及服务器端的双重数据验证任务。但要使服务器端验证功能发挥作用,还需要用到Page.IsValid属性,请看下面的例子: 

<form id="MyForm" runat="server">  
<div> 
  姓名:<asp:TextBox ID="txtName" runat="server"></asp:TextBox> 
<asp:RequiredField Validator ID="RequiredFieldValidator1" 
ControlToValidate="txtName" ErrorMessage="请填写 姓名!" Display="Dynamic" runat="server"></asp:RequiredFieldValidator> 
 </div>  
<div> 
  <asp:Button ID="btnSubmit" Text="提交" runat="server" />  
</div> 
</form> 

这是一个HTML片段,其中有一个RequiredFieldValidator控件用于检查是否已填写姓名。下面是点击按钮时执行的服务器端代码: 

protected void btnSubmit_Click(object sender, EventArgs e) 
{ 
  if (Page.IsValid) //注意:不要遗漏对Page.IsValid属性的判断   
{ 
    Response.Write("你的名字是:" + txtName.Text);   
}
 } 

其中,要特别注意对Page.IsValid属性的判断,只有页面中所有验证控件对数据的验证都成功时,Page.IsValid属性才为True,这代表提交的数据为有效数据,可以进入下一步操作。 

4.跳过表单验证 
在某些情况下,我们需要跳过表单中所有控件的验证,然而在另外一些情况下,我们却希望有选择的触发表单中某些控件的验证功能。分别来看看这两种情况: 
a.跳过所有验证 
假设有个表单,其中除了各种数据录入控件外还有两个按钮,一个是提交按钮,另一个是取消按钮,同时表单中还有一些数据验证控件。我们希望当点击取消按钮的时候无需验证表单中数据的有效性,而是直接将页面提交至服务器并将其重定向到某个指定页面。 
要实现这个功能,可以利用按钮控件(包括Button、LinkButton、ImageButton控件)的CausesValidation属性,将该属性设为false即可跳过表单中的所有验证。 
b.触发某些验证 
假设有个表单,被划分成两个功能区,一个用于用户登录,另一个用于用户注册,我们希望当点击登录按钮时只触发登录区的数据验证,当点击注册按钮时只触发注册区的数据验证。