从jQuery选择器中排除具有特定属性的元素

时间:2010-12-10 06:22:36

标签: javascript jquery css-selectors

我正在使用这个javascript在焦点时清空输入/ textarea。

   $(document).ready(function() {
    $('input[type="text"],textarea').not('[readonly="readonly"]').addClass("idleField");
    $('input[type="text"],textarea').focus(function() {
        $(this).removeClass("idleField").addClass("focusField");
        if (this.value == this.defaultValue){
            this.value = '';
        }
        if(this.value != this.defaultValue){
            this.select();
        }
    });
    $('input[type="text"],textarea').blur(function() {
        $(this).removeClass("focusField").addClass("idleField");
        if ($.trim(this.value) == ''){
            this.value = (this.defaultValue ? this.defaultValue : '');
        }
    });
   });

我正在寻找一种方法来排除那些input字段,这些字段通过readonly设置为readonly="readonly"。我知道我应该使用.not(我猜),但我无法弄清楚如何。

1 个答案:

答案 0 :(得分:8)

如果您希望所有可写入的输入元素(非只读),您可以使用以下选择器:

$("input:not([readonly])")

:not之后的参数是要匹配的选择器。 [readonly]将匹配readonly设置的任何内容。请注意,以下内容并不总是有效:

[readonly="readonly"]

你可以拥有这两个:

<input readonly type="text">
<input readonly="readonly" type="text">

你也可以使用“:input”伪造选择器代替“input,textarea”。请参阅文档here