今天在開發(fā)一個asp.net的頁面遇到了TextBox設置了ReadOnly屬性,在js中賦值后,后臺代碼取不到值的情況,經(jīng)過在網(wǎng)上查找,找到了一下幾個處理辦法。
收藏起來。
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");
}
}