• TextBox属性设为Readonly时,.net后端程序无法取值的问题解决 .


    原文是抄poolatu网友的,这是链接http://blog.csdn.net/poolatu/article/details/8671774

    TextBox属性设为Readonly时,C#后端程序无法取值的问题解决

    TextBox在Readonly時以Javascript給值無法在後端取得,我自己在测试的时候,在默认Readonly =false ,时也无法取值。系统提示无法找到这个("nametxtbox"控件,TextBox ID="nametxtbox")。
    .Net 2.0中使用TextBox元件﹐若設了readonly属性﹐例如 <asp:TextBox id="Text1" runat="server" Readonly="true"/>

    那么以Javascript给Text1值﹐则Postback之后﹐在程序后端无法以Text1.text取得內容值。

    我在网上查到的资料表示是.Net 2在安全性上的考量﹐解決的方法是在Page_Load以 Text1.Attributes.Add("readonly", "readonly");
    这种方式给TextBox Readonly的属性﹐如此即可以Text1.text的方式取得值。
    再不然就是改用Html元件的方式﹐以Request來接收值。

     

    解决案例 

    TextBox控件取值取不到的问题

    ====================================

     

    另外有很多人也遇到这样的类似的问题:在一个很多TextBox的页面上,控件里一开始就有值,这些值是用datareader读出来为每个控件赋值,然而在我要更新数据库的时候,用.Text来取TextBox控件里面的值,却取不到。难道是只读的?不管怎样最后有一个方法,用Request.Form来取值就可以取到了。

    顺便还有一点知识:

    .NET 2.0 中TextBox只读时在客户端赋值后的取值问题

    在.NET 2.0 下,当页面上的某个TextBox设置了属性ReadOnly="True"时,通过客户端脚本给其赋值后,在后台代码中访问其Text属性却无法获得该值。


     

    经过尝试,发现可以通过如下的方式解决这个问题:

    1、不设置ReadOnly属性,通过onfocus="this.blur()"来模拟,如下:

    <asp:TextBox ID="TextBox1" runat="server"onfocus="this.blur()"></asp:TextBox>
    在此情况下,当文本框获得焦点时便立刻失去,所以也无法手动修改其内容,能够模拟ReadOnly,在后台代码中也能通过Text属性,正常获取通过脚本在客户端设置的值;

    2、设置了ReadOnly属性后,通过Request来取值,如下:

    前台代码:

    <asp:TextBox ID="TextBox1" runat="server"ReadOnly="True"></asp:TextBox>
    后台代码:

    string Text = Request.Form["TextBox1"].Trim();
    3、在Page_Load()中设置文本框的只读属性,能正常读取,如下:

    protected void Page_Load(object sender, EventArgs e)
     
    {
     
          if (!Page.IsPostBack)
     
          ...{
     
              TextBox1.Attributes.Add("readonly","true");
     
          }
     
       }

     

  • 相关阅读:
    关于JDK 安装,以及Java环境的设置
    DHCP snooping
    解除破解正版Kindle电子书籍的版权限制
    广东地区电信官方DNS服务器
    Bash脚本15分钟进阶指导
    视听说英语
    华中师大2013新生群
    【强网杯2018】Gamebox
    【强网杯2018】逆向hide
    【Wechall.net挑战】Anderson Application Auditing
  • 原文地址:https://www.cnblogs.com/xushining/p/3244519.html
Copyright © 2020-2023  润新知