今天在开发一个asp.net的页面遇到了textbox设置了readonly属性,在js中赋值后,后台代码取不到值的情况,经过在网上查找,找到了一下几个处理办法。 
收藏起来。 
1、不设置readonly,设置onfocus=this.blur() 
c#代码 
<asp:textbox id="textbox1" runat="server" onfocus=this.blur()></asp:textbox> 
<asp:textbox id="textbox1" runat="server" onfocus=this.blur()></asp:textbox> 
文本框不变灰色,但也无法手动修改内容,可以在后台通过text属性正常赋值取值 
2、设置了readonly属性后,通过request来取值,如下: 
前台代码: 
<asp:textbox id="textbox1" runat="server" readonly="true" ></asp:textbox> 
<asp:textbox id="textbox1" runat="server" readonly="true" ></asp:textbox> 
后台代码: 
string text = request.form["textbox1"].trim(); 
string text = request.form["textbox1"].trim(); 
3、在page_load()正设置文本框的只读属性,能正常读取,如下: 
c#代码 
protected void page_load(object sender, eventargs e)  
{  
    if (!page.ispostback)  
    {  
        textbox1.attributes.add("readonly","true");  
    }  
}
                        
                        每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
                Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号