如何禁用双击Jquery模式对话框按钮?

时间:2013-03-21 11:47:10

标签: javascript jquery

我正在使用Jquery模式对话框将一些数据提交到服务器端,然后保存到数据库中;这里我的模态对话框代码是:

    function loadUserDialog(tag, event, target, id) {
            event.preventDefault();

$.validator.unobtrusive.parse('#frmModalPopup');

            var $loading = $('<img src="@Url.Content("~/Content/images/ajaxLoading.gif")" alt="loading" class="ui-loading-icon" style="margin: 150px 150px;">');
            var $url = $(tag).attr('href');
            var $title = $(tag).attr('title');
            var $dialog = $('<div></div>');
            $dialog.empty();
            $dialog
            .append($loading)
            .load($url)
              .dialog({
                  autoOpen: false
               , title: $title
               , width: 500
               , modal: true
               , minHeight: 400
               , show: 'fade'
               , hide: 'fade'
              });
            $dialog.dialog("option", "buttons", {
                "Submit": function () {
                    var dlg = $(this);
                    if (IsValidUserName() && $('#frmModalPopup').validate().form()) {
                        $.ajax({
                            url: $url,
                            type: 'POST',
                            data: $(target).serialize(),
                            success: function (response) {
                                var cid = $(response).attr('id');
                                if (cid != null && cid != undefined) {
                                    $(response).fadeIn('slow').appendTo(id);
                                    $(window).scrollTop($('#' + cid).offset().top);
                                }

                                dlg.dialog('close');
                                dlg.empty();
                            },
                            error: function (xhr) {
                                alertMessage("EmailId is already in use!");
                                $.validator.unobtrusive.parse('#frmModalPopup');
                            }
                        });
                    }
                },
                "Cancel": function () {
                    $(this).dialog('close');
                    $(this).empty();
                }
            });

            $dialog.dialog('open');
        };

但是当我多次点击“提交”按钮时(不止一次),表单会被提交多次,我收到了重复的数据提交信息。那么请你告诉我如何禁用双击或多次点击按钮提交。

4 个答案:

答案 0 :(得分:3)

首次提交时禁用对话框,在继续操作前检查是否已禁用,如果已经禁用则返回。

"Submit": function () {
  if ($(this).hasClass("disabled"))
    return;

  $(this).addClass("disabled");

  // continue;
}

编辑:您可以使用此方法添加一些额外的用户界面响应,方法是在禁用它时添加“工作...”或其他消息

$(this).addClass("disabled");
$dialog.append("Working...");

答案 1 :(得分:0)

jquery ui有一个名为isOpen()的好函数。 如果对话框已关闭但我们可以看到它以防止下一次单击,我们可以使用函数isOpen():

"Submit": function () {
    if( $(this).dialog("isOpen") ){
        YOUR CODE           
    } else {
        return false;
    }
    $(this).dialog("close");
}

答案 2 :(得分:0)

我需要禁用该按钮以避免双击,但是我需要在提交异步表单后重新启用该按钮。

为此,我使用一个window变量,它不是很优雅,但是可以起作用:

function openDialog() {
    window.clickOk = false;
    $("#divAnagrafica").dialog({
      ......
        buttons: [
                {
                    text: "Ok",
                    click: function () {
                        if (window.clickOk === true) {
                            return; 
                        }
                        window.clickOk = true;
                        $("#myForm").submit();
                    }
                },

答案 3 :(得分:-1)

您可以在第一次单击时立即禁用按钮上的指针事件:

  

pointer-events CSS属性在什么情况下设置(如果   任何)特定图形元素可以成为指针的目标   事件

指针事件:无表示:

  

该元素永远不会是指针事件的目标;但是,指针   如果事件的后代具有   指针事件设置为其他值。在这种情况下   指针事件将触发此父元素上的事件侦听器,如下所示:   在活动期间适合去往/离开后代的方式   捕获/气泡阶段。

click: function (e) {
   //your code to open dialogue etc..
   `$`(e.target).css('pointer-events', 'none');
   //your code}