JQuery 設定checkbox select radio 為“唯讀”

來源:互聯網
上載者:User

標籤:style   blog   http   java   使用   strong   

 

JQuery  設定checkbox select radio 為“唯讀”,通過測試知道使用HTML標籤的 text 和 textarea 、button 可以設定readonly="readonly"屬性。

但是checkbox 、select、 radio 這三個控制項使用起來不能使用readonly="readonly"屬性,只有 disabled="disabled"可以使用。

這樣就出現問題了。又想不讓修改,又想在後台擷取值。如果使用disabled屬性,但是發現(string value = Request.Form["XX"];)值為空白。

不想修改後台代碼,最後在和博哥的討論之下,終於想出了下面的方法。

[html] view plaincopyprint?
  1. <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %>  
  2.   
  3. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">  
  4. <html xmlns="http://www.w3.org/1999/xhtml">  
  5. <head runat="server">  
  6.     <title></title>  
  7.     <script src="Scripts/jquery-1.4.1.min.js" type="text/javascript"></script>  
  8.     <script type="text/javascript">  
  9.         function setSCR_ReadOnly() {  
  10.             var items = $("input[type=‘checkbox‘]")  
  11.             var html = ""  
  12.             for (var i = 0; i < items.length; i++) {  
  13.                 items[i].disabled = true;  
  14.                 html += "<input type=‘text‘ name=‘" + items[i].id + "‘ value=‘" + items[i].value + "‘>";  
  15.             }  
  16.   
  17.             var items = $("select");  
  18.             for (var i = 0; i < items.length; i++) {  
  19.                 html += "<input type=‘text‘ name=‘" + items[i].id + "‘ value=‘" + items[i].value + "‘>";  
  20.                 items[i].disabled = true;  
  21.             }  
  22.   
  23.             var items = $(":radio");  
  24.             for (var i = 0; i < items.length; i++) {  
  25.                 html += "<input type=‘text‘ name=‘" + items[i].id + "‘ value=‘" + items[i].value + "‘>";  
  26.                 items[i].disabled = true;  
  27.             }  
  28.             $("#divhtml").html(html);  
  29.   
  30.   
  31.         }  
  32.     </script>  
  33. </head>  
  34. <body>  
  35.     <form id="form1" runat="server">  
  36.     <div>  
  37.         <input type="text" readonly="readonly" />  
  38.         <input  type="button" value="不可用" onclick="setSCR_ReadOnly()" />  
  39.         <input  type="checkbox" id="r" checked="checked" runat="server" value="cboVAlue" />  
  40.         <select  id="sel" name="sel">  
  41.             <option value="請選擇">請選擇</option>  
  42.             <option value="1">1</option>  
  43.         </select>  
  44.         <select id="Select1" name="Select1">  
  45.             <option value="請選擇">請選擇</option>  
  46.             <option value="1" selected="selected">1</option>  
  47.         </select>  
  48.         <input  id="rdo" name="rdo" type="radio" value="1" checked="checked" />  
  49.         <asp:Button runat="server" Text="Button" onclick="Unnamed1_Click" />  
  50.         <div style="display: none" id="divhtml">  
  51.         </div>  
  52.     </div>  
  53.     </form>  
  54. </body>  
  55. </html>  
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head runat="server">    <title></title>    <script src="Scripts/jquery-1.4.1.min.js" type="text/javascript"></script>    <script type="text/javascript">        function setSCR_ReadOnly() {            var items = $("input[type=‘checkbox‘]")            var html = ""            for (var i = 0; i < items.length; i++) {                items[i].disabled = true;                html += "<input type=‘text‘ name=‘" + items[i].id + "‘ value=‘" + items[i].value + "‘>";            }            var items = $("select");            for (var i = 0; i < items.length; i++) {                html += "<input type=‘text‘ name=‘" + items[i].id + "‘ value=‘" + items[i].value + "‘>";                items[i].disabled = true;            }            var items = $(":radio");            for (var i = 0; i < items.length; i++) {                html += "<input type=‘text‘ name=‘" + items[i].id + "‘ value=‘" + items[i].value + "‘>";                items[i].disabled = true;            }            $("#divhtml").html(html);        }    </script></head><body>    <form id="form1" runat="server">    <div>        <input type="text" readonly="readonly" />        <input  type="button" value="不可用" onclick="setSCR_ReadOnly()" />        <input  type="checkbox" id="r" checked="checked" runat="server" value="cboVAlue" />        <select  id="sel" name="sel">            <option value="請選擇">請選擇</option>            <option value="1">1</option>        </select>        <select id="Select1" name="Select1">            <option value="請選擇">請選擇</option>            <option value="1" selected="selected">1</option>        </select>        <input  id="rdo" name="rdo" type="radio" value="1" checked="checked" />        <asp:Button runat="server" Text="Button" onclick="Unnamed1_Click" />        <div style="display: none" id="divhtml">        </div>    </div>    </form></body></html>
將這些控制項設定為disabled以後,發現這些控制項就可以擷取值。 [csharp] view plaincopyprint?
  1. using System;  
  2. using System.Collections.Generic;  
  3. using System.Linq;  
  4. using System.Web;  
  5. using System.Web.UI;  
  6. using System.Web.UI.WebControls;  
  7.   
  8. public partial class _Default : System.Web.UI.Page  
  9. {  
  10.     protected void Page_Load(object sender, EventArgs e)  
  11.     {  
  12.          
  13.     }  
  14.     protected void Unnamed1_Click(object sender, EventArgs e)  
  15.     {  
  16.         string value = Request.Form["r"];  
  17.         string q = Request.Form["sel"];  
  18.         string s = Request.Form["Select1"];  
  19.         string w = Request.Form["rdo"];  
  20.     }  
  21. }  

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.