.NET中TextBox控件設置ReadOnly=true後臺取不到值的解決方法

在.NET 2.0 下,當頁面上的某個TextBox 設置了屬性ReadOnly="True"時,經過客戶端腳本給其賦值後,在後臺代碼中訪問其Text屬性卻沒法得到該值。通過嘗試,發現能夠經過以下的方式解決這個問題:

方法一:不設置ReadOnly屬性,經過onfocus=this.blur()來模擬,以下:
複製代碼 代碼以下:

<asp:TextBox ID="TextBox1" runat="server" onfocus=this.blur()></asp:TextBox>

在此狀況下,當文本框得到焦點時便馬上失去,因此也沒法手動修改其內容,可以模擬ReadOnly,在後臺代碼中也能經過Text屬性,正常獲取經過腳本在客戶端設置的值;

方法二:設置了ReadOnly屬性後,經過Request來取值,以下:
前臺代碼:
複製代碼 代碼以下:

<asp:TextBox ID="TextBox1" runat="server" ReadOnly="True" ></asp:TextBox>

後臺代碼:
複製代碼 代碼以下:

string Text = Request.Form["TextBox1"].Trim();

方法三:在Page_Load()正設置文本框的只讀屬性,在前臺不設置。就能正常讀取,以下:
複製代碼 代碼以下:

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

 方法四:再就是經過js在客戶端加個按鈕事件,先去掉readonly屬性,再激活提交按鈕的click時間,在這裏我用的jquery來處理的,也能夠實現jquery

相關文章
相關標籤/搜索