【问题标题】:Set readonly property to false for an HTML text input on clicking an anchor tag在单击锚标记时将 HTML 文本输入的 readonly 属性设置为 false
【发布时间】:2013-04-24 06:40:41
【问题描述】:

我的 HTML:

<div class="profileForm">
    <fieldset>
    <label>Name<input type="text" id="name" name="name" runat="server" readonly=""/></label>
    <label>Email<input type="email" id="email" name="email" runat="server" readonly=""/></label>
    <label>Date Of Birth<input type="date" id="dob" name="dob" runat="server" readonly=""/></label>
    <label>Address<input type="text" id="address" name="address" runat="server" readonly=""/></label>
    <label>City<input type="text" id="city" name="city" runat="server" readonly=""/></label>
    <label>State<input type="text" id="state" name="state" runat="server" readonly=""/></label>
    <label>Country<input type="text" id="country" name="country" runat="server" readonly=""/></label>
    <label>Access Level<input type="text" id="accessLevel" name="accessLevel" runat="server" readonly=""/></label>
    </fieldset>
</div>
<div class="profileEdit">
    <fieldset>
        <label><a href="#" id="Aname">edit</a></label>
        <label><a href="#" id="Aemail">edit</a></label>
        <label><a href="#" id="Adob">edit</a></label>
        <label><a href="#" id="Aaddress">edit</a></label>
        <label><a href="#" id="Acity">edit</a></label>
        <label><a href="#" id="Astate">edit</a></label>
        <label><a href="#" id="Acountry">edit</a></label>
    </fieldset>
</div>

我的 JavaScript

<script src="Scripts/jquery-1.7.1.js"></script>
<script type="text/javascript">
    $(document).ready(function () {
        console.log("document ready")
        $("profileEdit label a").click(
        function (e) {
            if (this.attr("id") == "Aname") {
                $("#name").attr("readonly", false);
            }
        });
    });
</script>

备用 JavaScript

<script type="text/javascript">
    $(document).ready(function () {
        console.log("document ready")
        $('#Aname').live('click', function () {
            $("#name").attr("readonly", false);
        });
    });
</script>

我要做的是在单击相应的锚字段时将相应输入文本字段的 readonly 属性设置为 false。我的 JavaScript 脚本都不起作用。

解决方案:结合@KaraokeStu,@bipin 回答 我正在使用 asp.net 4.5

$(document).ready(function () {
        console.log("document ready")
        $('.profileEdit label a').live('click', function () {
            alert("ctl00_ContentPlaceHolder1_" + this.id.substring(1, this.id.length));
            $("#" + "ctl00_ContentPlaceHolder1_" + this.id.substring(1, this.id.length)).prop('readonly', false);
            console.log($("#" + "ctl00_ContentPlaceHolder1_" + this.id.substring(1, this.id.length)).attr('readonly'))
            $("#" + "ctl00_ContentPlaceHolder1_" + this.id.substring(1, this.id.length)).focus();
            alert("done");
       });

    });

【问题讨论】:

  • 请说明您的要求。问题标题为“设置为真”,而问题的底线为“设置为假”。

标签: javascript jquery


【解决方案1】:

连同提供的答案,为了完成对readonly属性的描述,作为一个布尔属性,想提一下,与经典编程语言中使用的术语,其中布尔值是一个能够具有两种状态的变量:真或假,W3C 在 following way 中定义了一个布尔属性:

元素上布尔属性存在表示 true 值,而属性的不存在表示 false 值。

如果属性存在,它的值必须是空字符串 或属性的 ASCII 不区分大小写匹配的值 规范名称,没有前导或尾随空格。

注意:布尔属性中不允许使用值“true”和“false”。要表示假值,属性必须是 完全省略。

所以,jQuery

$("#demo").prop('readonly', false);

只是删除只读属性的语法

document.getElementById("demo").removeAttribute("readonly");

任何其他方法,例如将其设置为 false 或其他值(如 0)都不会“启用”输入...

【讨论】:

    【解决方案2】:

    readonly 属性是一个布尔值。您不能将其设置为truefalse,您可以将其设置为readonly 或根本不设置(readonly="" 错误,您可以不设置该值(readonly)或指定正确的值 (readonly="readonly"))。

    如果要更改 DOM 中元素的只读状态,请将 readonly 属性 设置为 truefalse。保留属性。

    $("#name").prop("readonly", false);
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
    <input id=name readonly>

    【讨论】:

    • 如果您以 readonly = "readonly" 开头,这是否有效? IE。而不是没有价值的只读?
    • 是的。这是完全等价的 HTML。
    【解决方案3】:

    不用 jQuery 也可以做到:

    设置readOnly:

    document.getElementById("name").readOnly = true;
    

    并取消设置:

    document.getElementById("name").readOnly = false;
    

    一切都是纯粹的Vanilla JS

    【讨论】:

      【解决方案4】:

      设置元素属性readonly="readonly"

      【讨论】:

        【解决方案5】:

        你要么这样做:

        $(selector).attr('readonly', 'readonly');
        $(selector).removeAttr('readonly');
        

        或者这个:

        $(selector).prop('readonly', true);
        $(selector).prop('readonly', false);
        

        切勿将两者混用。

        记住并不难。请记住,在使用 .attr() 时,您正在处理属性值。使用 .prop() 时,您正在处理 DOM 属性。

        【讨论】:

          【解决方案6】:

          您可以使用以下代码:

          <script>
          $(document).ready(function () {
              $(".profileEdit label a").each(function (e) {
                  $(this).click(function (elem) {
                     $("#" + this.id.substring(1,this.id.length)).attr("readonly", false); 
                  });
              });    
          });
          </script>
          

          如此处所示: http://jsfiddle.net/uDCgE/

          【讨论】:

          • 其实是个好主意。您的代码并没有等待点击。您可能需要删除 each(function(e){。另外,由于我使用的是 asp.net,因此我必须将 "ctl00_ContentPlaceHolder1_" 字符串添加到 id 的开头,因为 ClientId 不适用于 javascript 字符串。
          • 当你混合客户端和服务器端代码时,这一切都很有趣和游戏,嗯?
          • 这是我在结合你和@bipen answers.asp.net 更改所有 runat="server" 控件的 id 后得出的结果。
          【解决方案7】:
          $('div.profileEdit a').click(function() {
              // extract corresponding label id
              var labelId = $(this).attr('id').split('A')[1];
              // make corresponding label readonly
              $('input#'+labelId).attr('readonly','readonly');
          });
          

          【讨论】:

            【解决方案8】:

            为了将readonly设置为false,您需要从输入字段中完成删除属性:

            $("#name").removeAttr("readonly");
            

            【讨论】:

              【解决方案9】:

              更改元素的只读属性。使用prop()

               $("#name").prop('readonly', false);
              

              link 阅读更多关于 prop() 和 attr() 的信息

              【讨论】:

              • #name 是属性的名称还是 ID?
              • @cullub 它的 ID,如你所见,我使用的是 $("#name") jquery id 选择器(前面的# 是 id,. 是类)。
              • readonly=false in chrome 在这里不起作用,只有完全删除它才有效。
              【解决方案10】:

              试试这个

               $("#name").removeAttr('readonly');
              

              here.

              WORKING DEMO

              【讨论】:

                猜你喜欢
                • 2017-04-16
                • 2016-12-14
                • 1970-01-01
                • 1970-01-01
                • 2019-07-13
                • 1970-01-01
                • 1970-01-01
                • 1970-01-01
                • 1970-01-01
                相关资源
                最近更新 更多