JS賦值設置了readonly=true的TextBox時,後臺取不到值的問題

開發一個asp.net的頁面遇到了TextBox設置了ReadOnly屬性,在js中賦值後,後臺代碼取不到值的狀況,通過在網上查找,找到了一下幾個處理辦法。asp.net

收藏起來。this

一、不設置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屬性正常賦值取值.net

二、設置了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();orm

三、在Page_Load()正設置文本框的只讀屬性,能正常讀取,以下:
C#代碼 
protected void Page_Load(object sender, EventArgs e)  
{  
    if (!Page.IsPostBack)  
    {  
        TextBox1.Attributes.Add("readonly","true");  
    }  
}server

相關文章
相關標籤/搜索