当前位置: 首页 > 图文教程 > 网络编程 > ASP.NET > ASP.NET2.0中TextBox的两个有趣的属性

ASP.NET
ASP.NET开发:简化应用程序的开发支持Web标准
asp.net XMLHttpRequest实现用户注册前的验证
asp.net 页面间传值方法小结
asp.net url重写浅谈
asp.net 验证码生成和刷新及验证
C#精髓 GridView72大绝技 学习gridview的朋友必看
实例说明asp.net中的简单角色权限控制
asp.net网站开发包wq.dll打包下载
js与ASP.NET 中文乱码问题
asp.net checkbox 动态绑定id GridView删除提示
asp.net TextBox回车触发事件 图片在img显示
asp.net 脏字典过滤问题 用正则表达式来过滤脏数据
asp.NET 脏字过滤算法
asp.NET 脏字过滤算法 修改版
asp.net sql 数据库处理函数命令
asp.net Javascript 的几种写法与提示
ASP.NET MVC学习笔记
asp.net 中国身份证号码验证代码 非正则
Asp.net中使用Sqlite数据库的方法
asp.net 中文字符串提交乱码的解决方法

ASP.NET2.0中TextBox的两个有趣的属性


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-11-03   浏览: 67 ::
收藏到网摘: n/a

    在以前的ASP.NET 1.x版本中,设置为ReadOnly的TextBox控件在客户端更改了值后,在服务器端仍然可以得到修改后的值,但在ASP.NET 2.0中,这种做法已经限制。这是为了提高应用程序安全性所考虑的。下面就是TextBox控件获得数据的内部方法,由此可以看出ReadOnly的限制:
  
  protected virtual bool LoadPostData(string postDataKey, NameValueCollection postCollection)
  {
   base.ValidateEvent(postDataKey);
   string text1 = this.Text;
   string text2 = postCollection[postDataKey];
   if (!this.ReadOnly && !text1.Equals(text2, StringComparison.Ordinal))
   {
    this.Text = text2;
    return true;
   }
   return false;
  }
  
    这里限制的只是Text属性,而没有限制提交数据的名称/值的NameValueCollection,因此,通过Request["表单名称"]的方法仍然可以得到值的。下面的例子充分说明了这一点,并且提供了既使用ReadOnly,又可以通过Text属性获得值的方法:
  
  <%@ Page Language="C#" EnableViewState="false" %>
  
  <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  
  <script runat="server">
  
  protected void Button1_Click(object sender, EventArgs e)
  {
   Response.Write("<li>TextBox1 = " + TextBox1.Text);
   Response.Write("<li>TextBox2 = " + TextBox2.Text);
   Response.Write("<li>TextBox3 = " + TextBox3.Text);
   Response.Write("<li>Request.Form[TextBox1] = " + Request.Form[TextBox1.UniqueID]);
   Response.Write("<li>Request.Form[TextBox2] = " + Request.Form[TextBox2.UniqueID]);
   Response.Write("<li>Request.Form[TextBox3] = " + Request.Form[TextBox3.UniqueID]);
  }
  
  protected void Page_Load(object sender, EventArgs e)
  {
   TextBox3.Attributes.Add("readonly", "readonly");
  }
  </script>
  
  <script type="text/javascript">
  //<![CDATA[
  function SetNewValue()
  {
   document.getElementById('<%=TextBox1.ClientID %>').value = "TextBox1 new Value";
   document.getElementById('<%=TextBox2.ClientID %>').value = "TextBox2 new Value";
   document.getElementById('<%=TextBox3.ClientID %>').value = "TextBox3 new Value";
  }
  //]]>
  </script>
  
  <html xmlns="http://www.w3.org/1999/xhtml">
  <head runat="server">
  <title>ASP.NET 2.0中TextBox控件与ReadOnly和Enabled属性</title>
  </head>
  <body>
  <form id="form1" runat="server">
   <span>TextBox1 ReadOnly:</span>
   <asp:TextBox ID="TextBox1" runat="server" ReadOnly="True" Text="TextBox1 Old Value"></asp:TextBox><br />
   <span>TextBox2 Enabled:</span>
   <asp:TextBox ID="TextBox2" runat="server" Enabled="False" Text="TextBox2 Old Value"></asp:TextBox><br />
   <span>TextBox3 ReadOnly:</span>
   <asp:TextBox ID="TextBox3" runat="server" Text="TextBox3 Old Value"></asp:TextBox><br />
   <br />
   <asp:Button ID="Button2" runat="server" Text="修改新值" OnClientClick="SetNewValue();return false;" />
   <asp:Button ID="Button1" runat="server" Text="提交" OnClick="Button1_Click" />
  </form>
  </body>
  </html>
  
    对于disabled的TextBox,在服务器端不能得到修改的值,如果实在要用这个属性,那之后使用隐藏表单域的方法来实现了