Как я могу отключить кнопку в диалоговом окне jQuery UI?

143

Как мне отключить кнопку в диалоговом окне jQuery UI . Я не могу найти это в какой-либо документации по ссылке выше.

У меня 2 кнопки на модальном подтверждении («Подтвердить» и «Отмена»). В некоторых случаях я хочу отключить кнопку «Подтвердить».

Лиора
источник
Смотрите ответы в этой теме: stackoverflow.com/questions/577548/…
Эрик
5
@Erik - С тех пор эти ответы немного изменились, а именно из-за .button()плагина, поэтому они больше не обязательно являются лучшими / самыми чистыми решениями.
Ник Крейвер

Ответы:

158

Если вы включаете .button()плагин / виджет, который содержит пользовательский интерфейс jQuery (если у вас есть полная библиотека и вы используете 1.8+, вы можете использовать ее, чтобы отключить кнопку и визуально обновить состояние, например, так:

$(".ui-dialog-buttonpane button:contains('Confirm')").button("disable");

Вы можете попробовать его здесь ... или, если вы используете более старую версию или не используете виджет кнопки, вы можете отключить его следующим образом:

$(".ui-dialog-buttonpane button:contains('Confirm')").attr("disabled", true)
                                              .addClass("ui-state-disabled");

Если вы хотите это внутри определенного диалога, скажем, по идентификатору, то сделайте это:

$("#dialogID").next(".ui-dialog-buttonpane button:contains('Confirm')")
              .attr("disabled", true);

В других случаях, когда вы :contains()можете получить ложные срабатывания, вы можете использовать .filter()это так, но это излишне, так как вы знаете свои две кнопки. Если это так в других ситуациях, это будет выглядеть так:

$("#dialogID").next(".ui-dialog-buttonpane button").filter(function() {
  return $(this).text() == "Confirm";
}).attr("disabled", true);

Это предотвратит :contains()сопоставление подстроки чего-то еще.

Ник Крейвер
источник
next () не будет работать для меня, так как есть все «изменяемый размер» div между диалогом и кнопочной панелью. Поэтому я использовал nextAll () и отделил buttonPan от кнопки:$("#dialogID").nextAll(".ui-dialog-buttonpane").find("button:contains('Confirm')").attr("disabled", true).addClass("ui-state-disabled");
Matthieu
Обратите внимание, что из-за того, что панель кнопок не является дочерней по отношению к контейнеру диалогов, у вас могут возникнуть проблемы, если ваша страница определяет несколько диалогов.
Бретт Райан
Отличное решение, $(".ui-dialog-buttonpane button:contains('Confirm')").button("disable");хотя, если вы хотите отключить кнопку от функции, которая у вас есть для нее, вы должны добавить этот диалог в виджет и отключить кнопку после этого; как это$(this).dialog("widget").find(".ui-dialog-buttonpane button:contains('Confirm')").button("disable");
меридиус
3
Обратите внимание, что если вы не хотите запрашивать нужную кнопку по ее тексту, вы также можете назначить ей класс; Диалоговое окно jQuery UI поддерживает массив с объектами для опции кнопки, каждый объект содержит информацию об атрибутах кнопок.
Деннис
Это сработало для меня: $ (this) .closest (".ui-dialog"). Find ("кнопка: содержит ('Сохранить')"). Prop ("отключено", true) .addClass ("ui-state- отключен");
Адриан П.
217

Похоже, кто-то, даже в этом связанном вопросе , предложил это решение, подобное первой части ответа, данного Ником Крейвером:

$("#dialog").dialog({
    width: 480,
    height: "auto",
    buttons: [
        {
            id: "button-cancel",
            text: "Cancel",
            click: function() {
                $(this).dialog("close");
            }
        },
        {
            id: "button-ok",
            text: "Ok",
            click: function() {
                $(this).dialog("close");
            }
        }
    ]
});

Затем в другом месте вы сможете использовать API для кнопки пользовательского интерфейса jquery:

$("#button-ok").button("disable");
Никола Тувери
источник
15
+1. Я не уверен, почему этот ответ не получил больше голосов. Это самое чистое, с которым я сталкивался, и работает хорошо.
Дуг Уилсон
38
Это должно быть в документации ... это даже не показывает, что вы можете назначить идентификатор для кнопок.
Джей К
1
Это, без сомнения, лучший ответ. Существуют и другие решения, которые делают это путем поиска кнопки с помощью неправильных селекторов. Хорошая работа, Никола!
Джнорейга
4
Согласитесь: это решение, которое, как я думал, должна реализовать команда UI ...: +) Вы можете сделать это еще быстрее:{text:"ok",disabled:true,click: function(){}}
Матье
10
Это круто! Вы также можете использовать «класс» вместо «id», если вас беспокоит уникальность идентификатора. Хотя вам придется набрать немного больше, чтобы найти кнопку:$("#dialog").dialog("widget").find(".button-ok-class").button("enable")
desm
49

Вы также можете использовать не документированный disabledатрибут:

$("#element").dialog({
    buttons: [
    {
        text: "Confirm",
        disabled: true,
        id: "my-button-1"
    }, 
    {
        text: "Cancel",
        id: "my-button-2",
        click: function(){            
               $(this).dialog("close");
        }  

    }]
});

Чтобы включить после открытия диалога, используйте:

$("#my-button-1").attr('disabled', false);

JsFiddle: http://jsfiddle.net/xvt96e1p/4/

Жером
источник
Дело не в том, что это без документов. Дело в том, что когда кнопки обрабатываются, все свойства объекта выполняются по отношению к их эквиваленту свойства jQuery. Например, вы можете добавить, attr: { 'data-value' : 'some value here' }если хотите добавить атрибут data-valueк кнопке.
раздавить
2
Больше не документировано. Это официально.
Салман А
Это решение намного элегантнее, чем более популярная версия. Это дает вам всю гибкость без проблем с четко определенными селекторами.
KimvdLinde
Обратите внимание, что disabledатрибут должен быть назначен при создании кнопок.
user1032531
Пытался понизить голос, но я проголосовал 4 часа назад и не могу этого сделать. Это решение больше не работает должным образом.
user1032531 20.10.15
7

Следующее работает изнутри функции нажатия кнопок:

$(function() {
    $("#dialog").dialog({
        height: 'auto', width: 700, modal: true,
        buttons: {
            'Add to request list': function(evt) {

                // get DOM element for button
                var buttonDomElement = evt.target;
                // Disable the button
                $(buttonDomElement).attr('disabled', true);

                $('form').submit();
            },
            'Cancel': function() {
                $(this).dialog('close');
            }
        }
    });
}
Крис Питчманн
источник
но затем вы должны щелкнуть, прежде чем он станет серым.
Мэтт
1

Кнопка определяется классом ui-button. Чтобы отключить кнопку:

$("#myButton").addClass("ui-state-disabled").attr("disabled", true);

Если вы динамически не создаете диалог (что возможно), вы будете знать положение кнопки. Итак, чтобы отключить первую кнопку:

$("#myButton:eq(0)").addClass("ui-state-disabled").attr("disabled", true);

ui-state-disabledКласс , что дает кнопку, хорошее затемненному стиль.

Крис Лапланте
источник
1

Я создал функцию jQuery, чтобы облегчить эту задачу. Вероятно, теперь есть лучшее решение ... в любом случае, вот мои 2cents. :)

Просто добавьте это в ваш файл JS:

$.fn.dialogButtons = function(name, state){
var buttons = $(this).next('div').find('button');
if(!name)return buttons;
return buttons.each(function(){
    var text = $(this).text();
    if(text==name && state=='disabled') {$(this).attr('disabled',true).addClass('ui-state-disabled');return this;}
    if(text==name && state=='enabled') {$(this).attr('disabled',false).removeClass('ui-state-disabled');return this;}
    if(text==name){return this;}
    if(name=='disabled'){$(this).attr('disabled',true).addClass('ui-state-disabled');return buttons;}
    if(name=='enabled'){$(this).attr('disabled',false).removeClass('ui-state-disabled');return buttons;}
});};

Отключить кнопку «ОК» в диалоге с классом «диалог»:

$('.dialog').dialogButtons('Ok', 'disabled');

Включить все кнопки:

$('.dialog').dialogButtons('enabled');

Включите кнопку «Закрыть» и измените цвет:

$('.dialog').dialogButtons('Close', 'enabled').css('color','red');

Текст на всех кнопках красный:

$('.dialog').dialogButtons().css('color','red');

Надеюсь это поможет :)

sergiodlopes
источник
1
function getDialogButton( jqUIdialog, button_names )
{
    if (typeof button_names == 'string')
        button_names = [button_names];
    var buttons = jqUIdialog.parent().find('.ui-dialog-buttonpane button');
    for (var i = 0; i < buttons.length; i++)
    {
        var jButton = $( buttons[i] );
        for (var j = 0; j < button_names.length; j++)
            if ( jButton.text() == button_names[j] )
                return jButton;
    }

    return null;
}

function enableDialogButton( jqUIdialog, button_names, enable )
{
    var button = getDialogButton( jqUIdialog, button_names );
    if (button == null)
        alert('button not found: '+button_names);
    else
    {
        if (enable)
            button.removeAttr('disabled').removeClass( 'ui-state-disabled' );
        else
            button.attr('disabled', 'disabled').addClass( 'ui-state-disabled' );
    }
}
Ронни Шерер
источник
1

Вы можете перезаписать массив кнопок и оставить только те, которые вам нужны.

$( ".selector" ).dialog( "option", "buttons", [{
    text: "Close",
    click: function() { $(this).dialog("close"); }
}] );
jfredys
источник
1

этот код отключает кнопку с помощью YOUR_BUTTON_LABEL. Вы можете заменить имя в содержит (). отключить

$(".ui-dialog-buttonpane button:contains('YOUR_BUTTON_LABEL')").button("disable");

замените YOUR_BUTTON_LABEL на ярлык вашей кнопки. включить

$(".ui-dialog-buttonpane button:contains('YOUR_BUTTON_LABEL')").button("enable");
Sumeet_Pol
источник
0

Вы можете сделать это, чтобы отключить первую кнопку, например:

$('.ui-dialog-buttonpane button:first').attr('disabled', 'disabled');
Дарин димитров
источник
0

То, как я это делаю Cancel: function(e) { $(e.target).attr( "disabled","disabled" ); }

Это самый короткий и простой способ, который я нашел.

Bhavin
источник
0

Если вы используете нокаут, то это даже чище. Представьте, что у вас есть следующее:

var dialog = $('#my-dialog').dialog({
    width: '100%',
    buttons: [
        { text: 'Submit', click: $.noop, 'data-bind': 'enable: items() && items().length > 0, click: onSubmitClicked' },
        { text: 'Enable Submit', click: $.noop, 'data-bind': 'click: onEnableSubmitClicked' }
    ]
});

function ViewModel(dialog) {
    var self = this;

    this.items = ko.observableArray([]);

    this.onSubmitClicked = function () {
        dialog.dialog('option', 'title', 'On Submit Clicked!');
    };

    this.onEnableSubmitClicked = function () {
        dialog.dialog('option', 'title', 'Submit Button Enabled!');
        self.items.push('TEST ITEM');
        dialog.text('Submit button is enabled.');
    };
}

var vm = new ViewModel(dialog);
ko.applyBindings(vm, dialog.parent()[0]); //Don't forget to bind to the dialog parent, or the buttons won't get bound.
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<link rel="stylesheet" href="//ajax.googleapis.com/ajax/libs/jqueryui/1.11.2/themes/smoothness/jquery-ui.css" />
<script src="//ajax.googleapis.com/ajax/libs/jqueryui/1.11.2/jquery-ui.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/knockout/3.2.0/knockout-min.js"></script>

<div id="my-dialog">
  Submit button is disabled at initialization.
</div>

Волшебство исходит из источника пользовательского интерфейса jQuery :

$( "<button></button>", props )

Вы можете вызвать ЛЮБУЮ функцию экземпляра jQuery, передав ее через объект кнопки.

Например, если вы хотите использовать HTML:

{ html: '<span class="fa fa-user"></span>User' }

Или, если вы хотите добавить класс к кнопке (вы можете сделать это несколькими способами):

{ addClass: 'my-custom-button-class' }

Может быть, вы с ума сошли и хотите убрать кнопку из домена, когда она зависла:

{ mouseover: function () { $(this).remove(); } }

Я действительно удивлен, что никто, кажется, не упомянул это в бесчисленном количестве тем, как это ...

раздавить
источник
0

Это сработало для меня -

$("#dialog-confirm").html('Do you want to permanently delete this?');
$( "#dialog-confirm" ).dialog({
    resizable: false,
    title:'Confirm',
    modal: true,
    buttons: {
        Cancel: function() {
            $( this ).dialog( "close" );
        },
        OK:function(){
            $('#loading').show();
            $.ajax({
                    type:'post',
                    url:'ajax.php',
                    cache:false,
                    data:{action:'do_something'},
                    async:true,
                    success:function(data){
                        var resp = JSON.parse(data);
                        $("#loading").hide();
                        $("#dialog-confirm").html(resp.msg);
                        $( "#dialog-confirm" ).dialog({
                                resizable: false,
                                title:'Confirm',
                                modal: true,
                                buttons: {
                                    Close: function() {
                                        $( this ).dialog( "close" );
                                    }
                                }
                        });
                    }
                });
        }
    }
}); 
Прамод Кумар
источник
0

Вы можете отключить кнопку при создании диалога:

$(function() {
  $("#dialog").dialog({
    modal: true,
    buttons: [
      { text: "Confirm", click: function() { $(this).dialog("close"); }, disabled: true },
      { text: "Cancel", click: function() { $(this).dialog("close"); } }
    ]
  });
});
@import url("https://code.jquery.com/ui/1.11.4/themes/smoothness/jquery-ui.min.css");
<script src="https://code.jquery.com/jquery-1.11.3.min.js"></script>
<script src="https://code.jquery.com/ui/1.11.4/jquery-ui.min.js"></script>

<div id="dialog" title="Confirmation">
  <p>Proceed?</p>
</div>

Или вы можете отключить его в любое время после создания диалога:

$(function() {
  $("#dialog").dialog({
    modal: true,
    buttons: [
      { text: "Confirm", click: function() { $(this).dialog("close"); }, "class": "confirm" },
      { text: "Cancel", click: function() { $(this).dialog("close"); } }
    ]
  });
  setTimeout(function() {
    $("#dialog").dialog("widget").find("button.confirm").button("disable");
  }, 2000);
});
@import url("https://code.jquery.com/ui/1.11.4/themes/smoothness/jquery-ui.min.css");
<script src="https://code.jquery.com/jquery-1.11.3.min.js"></script>
<script src="https://code.jquery.com/ui/1.11.4/jquery-ui.min.js"></script>

<div id="dialog" title="Confirmation">
  <p>Button will disable after two seconds.</p>
</div>

Салман А
источник