禁用/启用按钮和链接的最简单方法是什么(jQuery + Bootstrap)


360

有时我使用样式设置为按钮的锚,有时我仅使用按钮。我想禁用特定的clicky-thing,以便:

  • 他们看起来很残疾
  • 他们不再被点击

我怎样才能做到这一点?


看到我的帖子在最底端,但这是描述较少的$(“ yourSelector”)。button(“ enable”); //启用按钮或$(“ yourSelector”)。button(“ disable”); //如果使用jqueryUI中的按钮小部件,则禁用按钮。
El Bayames 2015年

BS3文档说可role="button"用于链接,但这似乎并不影响此问题。 getbootstrap.com/css/#buttons
Jess

2
a.btn[disabled]出现残疾但仍然可点击是引导一个bug IMO。该属性[disabled]应仅显示为button和禁用input
杰西(Jess)

Answers:


575

纽扣

按钮很容易禁用,disabled而按钮属性是由浏览器处理的:

<input type="submit" class="btn" value="My Input Submit" disabled/>
<input type="button" class="btn" value="My Input Button" disabled/>
<button class="btn" disabled>My Button</button>

要使用自定义jQuery函数禁用这些功能,您只需使用fn.extend()

// Disable function
jQuery.fn.extend({
    disable: function(state) {
        return this.each(function() {
            this.disabled = state;
        });
    }
});

// Disabled with:
$('input[type="submit"], input[type="button"], button').disable(true);

// Enabled with:
$('input[type="submit"], input[type="button"], button').disable(false);

JSFiddle禁用了按钮和输入演示

否则,您将使用jQuery的prop()方法:

$('button').prop('disabled', true);
$('button').prop('disabled', false);

锚标签

值得注意的是,这disabled不是锚标记的有效属性。因此,Bootstrap在其.btn元素上使用以下样式:

.btn.disabled, .btn[disabled] {
    cursor: default;
    background-image: none;
    opacity: 0.65;
    filter: alpha(opacity=65);
    -webkit-box-shadow: none;
    -moz-box-shadow: none;
    box-shadow: none;
    color: #333;
    background-color: #E6E6E6;
}

请注意该[disabled]属性以及一个.disabled类的目标。该.disabled班是什么是需要做一个锚定标记显示为禁用。

<a href="http://example.com" class="btn">My Link</a>

当然,这不会阻止单击链接。上面的链接会将我们带到http://example.com。为了防止这种情况,我们可以添加一个简单的jQuery代码片段,以将disabled要调用的类定位到定位标记event.preventDefault()

$('body').on('click', 'a.disabled', function(event) {
    event.preventDefault();
});

我们可以disabled使用toggleClass()以下方法切换类:

jQuery.fn.extend({
    disable: function(state) {
        return this.each(function() {
            var $this = $(this);
            $this.toggleClass('disabled', state);
        });
    }
});

// Disabled with:
$('a').disable(true);

// Enabled with:
$('a').disable(false);

JSFiddle禁用了链接演示


组合式

然后,我们可以扩展上面制作的上一个disable函数,以检查要尝试使用禁用的元素的类型is()。这样,toggleClass()如果不是inputor button元素,我们可以进行切换,disabled如果不是,则可以切换属性:

// Extended disable function
jQuery.fn.extend({
    disable: function(state) {
        return this.each(function() {
            var $this = $(this);
            if($this.is('input, button, textarea, select'))
              this.disabled = state;
            else
              $this.toggleClass('disabled', state);
        });
    }
});

// Disabled on all:
$('input, button, a').disable(true);

// Enabled on all:
$('input, button, a').disable(false);

完全组合的JSFiddle演示

值得进一步指出的是,上述功能也适用于所有输入类型。


感谢您的全面答复。请参阅我的Edit 1以获取咖啡脚本版本。我仍在努力获取链接以防止点击。您对我来说是要保留 return false if $(@).prop('disabled')自定义点击处理程序吗?没有那条线,这些处理程序无论如何都会运行。
biofractal

1
我提到的@biofractal disabled不是有效的锚标记属性,因此不应使用。我提供的click事件基于.disabled该类,但是您可以使用hasClass('disabled')-如果为true,则可以使用preventDefault
詹姆斯·唐纳利

喔好吧。谢谢。那么,为什么不应该disabled在锚点上创建和使用该属性呢?它是一个动态对象,因此我可以设置它并使用它,就像我扩展了锚点的功能集一样?我在下面更新了我的答案以显示这一点。你怎么看?是邪恶的吗?另外,你必须.off()preventDefaultclick事件,当您重新启用的链接?
biofractal

它违反规范,并且不会通过验证测试。如果需要自定义disabled属性,则可以使用data-*属性。由于Bootstrap已经将相同的disabled属性样式应用于class="disabled"您,因此也可以依赖于该类。
詹姆斯·唐纳利

知道了-我已对我的回答进行了调整以反映您的评论。我仍然担心,如果我挂接了preventDefault所有锚点单击事件,那么当重新启用链接时,我将需要分离它们。还是我误会了什么?
biofractal

48

我想不出更简单/更简单的方法!;-)


使用锚标签(链接):

<a href="#delete-modal" class="btn btn-danger" id="delete">Delete</a>

要启用Anchor标签:

 $('#delete').removeClass('disabled');
 $('#delete').attr("data-toggle", "modal");

在此处输入图片说明


禁用锚标记:

 $('#delete').addClass('disabled');
 $('#delete').removeAttr('data-toggle');

在此处输入图片说明


27

假设您有文本字段和提交按钮,

<input type="text" id="text-field" />
<input type="submit" class="btn" value="Submit"/>

禁用:

要禁用任何按钮,例如,提交按钮,您只需添加“ disabled”属性为,

$('input[type="submit"]').attr('disabled','disabled');

执行以上行后,您的Submit button html标记将如下所示:

<input type="submit" class="btn" value="Submit" disabled/>

请注意已添加了“禁用”属性

启用:

用于启用按钮,例如在文本字段中有一些文本时。您需要删除disable属性以启用按钮,因为

 if ($('#text-field').val() != '') {
     $('input[type="submit"]').removeAttr('disabled');
 }

现在,上面的代码将删除“ disabled”属性。


22

我知道我晚会晚了,但是要具体回答两个问题:

“我只想禁用特定的clicky-thing,以便:

  • 他们停止点击
  • 他们看起来很残疾

这有多难?”

他们停止点击

1.对于诸如<button>或的按钮,<input type="button">您添加属性:disabled

<button type="submit" disabled>Register</button>
<input type="button" value="Register" disabled>

2.对于链接,任何链接...实际上,对于任何HTML元素,都可以使用CSS3 指针事件

.selector { pointer-events:none; }

根据当今的最新状态(2014年5月12日),浏览器对指针事件的支持非常棒。但是我们通常必须在IE领域中支持旧版浏览器,因此IE10及以下版本不支持指针事件:http : //caniuse.com/pointer-events。因此,使用此处其他人提到的JavaScript解决方案之一可能是旧版浏览器的方法。

有关指针事件的更多信息:

他们看起来很残疾

显然,这是一个CSS答案,因此:

1.对于类似<button><input type="button">使用[attribute]选择器的按钮:

button[disabled] { ... }

input[type=button][disabled] { ... }

-

这是一个基本的演示,其中包含我在这里提到的内容:http : //jsfiddle.net/bXm5B/4/

希望这可以帮助。


17

如果像我一样,您只想禁用按钮,请不要错过隐藏在此长线程中的简单答案:

 $("#button").prop('disabled', true);

真正的英雄,这就是我所需要的。
里克斯(Ricks)

7

@James Donnelly提供了一个全面的答案,该答案依赖于使用新功能扩展jQuery。那是个好主意,因此我将调整他的代码,使其按我需要的方式工作。

扩展jQuery

$.fn.disable=-> setState $(@), true
$.fn.enable =-> setState $(@), false
$.fn.isDisabled =-> $(@).hasClass 'disabled'

setState=($el, state) ->
    $el.each ->
        $(@).prop('disabled', state) if $(@).is 'button, input'
        if state then $(@).addClass('disabled') else $(@).removeClass('disabled')

    $('body').on('click', 'a.disabled', -> false)

用法

$('.btn-stateful').disable()
$('#my-anchor').enable()

该代码将处理单个元素或元素列表。

按钮和输入支持disabled属性,如果设置为true,则它们将被禁用(由于引导),并且单击时不会触发。

锚不支持禁用的属性,因此,而不是我们要依靠.disabled类,使它们看起来禁用(感谢再次引导)和挂钩默认点击事件,可防止通过点击返回false(无需preventDefault这里) 。

注意:重新启用锚点时,您无需取消挂钩此事件。只需删除.disabled类即可解决问题。

当然,如果您在链接上附加了自定义点击处理程序,这将无济于事,这在使用引导程序和jQuery时非常常见。因此,为了解决这个问题,我们将使用isDisabled()扩展名对该.disabled类进行测试,如下所示:

$('#my-anchor').click -> 
    return false if $(@).isDisabled()
    # do something useful

我希望这有助于简化事情。


7

请注意,如果您使用的是Bootstrap的JS按钮和“加载”状态,则会出现一个奇怪的问题。我不知道为什么会这样,但是下面是解决方法。

假设您有一个按钮,并将其设置为加载状态:

var myButton = $('#myBootstrapButton');
myButton.button('loading');

现在,您要将其从加载状态中删除,但也将其禁用(例如,该按钮是“保存”按钮,加载状态指示正在进行的验证,并且验证失败)。这看起来像是合理的Bootstrap JS:

myButton.button('reset').prop('disabled', true); // DOES NOT WORK

不幸的是,这将重置按钮,但不会禁用它。显然,button()执行一些延迟的任务。因此,您还必须推迟禁用时间:

myButton.button('reset');
setTimeout(function() { myButton.prop('disabled', true); }, 0);

有点烦人,但这是我经常使用的模式。


6

所有人的好评和贡献!我不得不稍微扩展此功能,以包括禁用选择元素:

jQuery.fn.extend({
disable: function (state) {
    return this.each(function () {
        var $this = jQuery(this);
        if ($this.is('input, button'))
            this.disabled = state;
        else if ($this.is('select') && state)
            $this.attr('disabled', 'disabled');
        else if ($this.is('select') && !state)
            $this.removeAttr('disabled');
        else
            $this.toggleClass('disabled', state);
    });
}});

似乎为我工作。谢谢大家!


5

对于这种行为,我始终使用jQueryUI button小部件,将其用于链接和按钮。

在HTML中定义标签:

<button id="sampleButton">Sample Button</button>
<a id="linkButton" href="yourHttpReferenceHere">Link Button</a>

使用jQuery初始化按钮:

$("#sampleButton").button();
$("#linkButton").button();

使用button小部件方法来禁用/启用它们:

$("#sampleButton").button("enable"); //enable the button
$("#linkButton").button("disable"); //disable the button

这将解决按钮和光标的行为,但是如果您需要更深入地了解并在禁用时更改按钮样式,则可以覆盖页面CSS样式文件中的以下CSS类。

.ui-state-disabled,
.ui-widget-content .ui-state-disabled,
.ui-widget-header .ui-state-disabled {
      background-color:aqua;
      color:black;
 }

但是请记住:那些CSS类(如果已更改)也将更改其他小部件的样式。


1
很肯定这个答案是对的jQuery UI按钮不能用于引导按钮与普通的香草jQuery的,后者是什么OP是使用使用。顺便说一句,在问题的评论中加上答案不是传播的首选方法。; ^)
ruffin

3

以下对我非常有效:

$("#button").attr('disabled', 'disabled');

2

这是一个比较晚的答案,但是我偶然发现了这个问题,同时在寻找一种方法来单击单击后禁用boostrap按钮,并可能添加一个不错的效果(例如微调器)。我发现了一个出色的库,它确实可以做到:

http://msurguy.github.io/ladda-bootstrap/

您只需包括所需的CSS和JS,向按钮添加一些属性,然后使用javascript启用lada。您的按钮焕然一新(请查看演示以了解它的美丽)!


2

上面的方法行不通,因为有时

$(this).attr('checked') == undefined

调整您的代码

if(!$(this).attr('checked') || $(this).attr('checked') == false){

2

我知道我的答案来晚了,但是IMO这是切换“启用”和“禁用”按钮的最简单方法

function toggleButtonState(button){

  //If button is enabled, -> Disable
  if (button.disabled === false) {
    button.disabled = true;

  //If button is disabled, -> Enable
  } else if (button.disabled === true) {
    button.disabled = false;
  }
}

1

假设您在页面上有这些按钮,例如:

<input type="submit" class="byBtn" disabled="disabled" value="Change"/>
<input type="submit" class="byBtn" disabled="disabled" value="Change"/>
<input type="submit" class="byBtn" disabled="disabled" value="Change"/>
<input type="submit" class="byBtn" disabled="disabled" value="Change"/>
<input type="submit" class="byBtn" disabled="disabled" value="Change"/>
<input type="submit"value="Enable All" onclick="change()"/>

js代码:

function change(){
   var toenable = document.querySelectorAll(".byBtn");        
    for (var k in toenable){
         toenable[k].removeAttribute("disabled");
    }
}

1

假设您具有当前启用的外观。

<button id="btnSave" class="btn btn-info">Save</button>

只需添加:

$("#btnSave").prop('disabled', true);

你会得到这个将禁用按钮

<button id="btnSave" class="btn btn-primary" disabled>Save</button>

2
该问题询问按钮锚点。该disabled属性不是锚标记的有效属性。
biofractal

0

如果要禁用可点击的控件,也可以在html中内联添加

style="cursor: not-allowed;"
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.