在.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