21

我正在使用 jquery ui 对话框,我从 jquery ui 网站下载它,版本是 jquery-ui-1.10.2.custom.min.js,jquery 是 jquery-1.9.1.js,它与 jquery ui js 捆绑在一起,但是现在我遇到一个问题:当打开对话框并单击保存按钮时,我希望关闭对话框,这是我的代码:

$(function(){
 $("#dialog-form").dialog({
     autoOpen: false,
     height: 350,
     width: 450,
     modal: true,
     buttons: {
       "save": function() {
           if(!checkDept()){
               return ;
           }
           $.post('dept_save.do', 
                 {'dept.deptId':$("#dialog_dept_deptId").val(), 
                  'dept.deptName':$("#dialog_dept_deptName").val(),
                  'dept.manager':$("#dialog_dept_manager").val(),
                 },function(data, status, xhr){
                     if(status == 'success'){
                         alert('save success');
                         $(this).dialog("close");
                     }else{
                         alert('error:'+data);
                     }
                  }
                 ,"json");
       }
     },
     close: function() {
         $(this).dialog("close");
     }
   });

     /* to open dialog*/
    $("#add").click(function(){
        $("#dialog-form").dialog("open");
    });

现在当我关闭“保存成功”弹出对话框时,dialog-form对话框没有关闭,并且发生错误:

未捕获的错误:无法在初始化之前调用对话框上的方法;试图调用方法“关闭”jquery-1.9.1.js:507。

还有另一个错误:

Uncaught SyntaxError: Unexpected token o jquery-1.9.1.js:541

谢谢。

4

6 回答 6

33

this一旦你在里面,你就会失去上下文$.post()。在 $.post 之前,将上下文保存在该保存按钮函数this内的变量中。

$('#dialog-form').dialog({
     // .....
     buttons: {
        'save': function() { 

            var $this = $(this); 
                      // -this- is still the original context 
                      // of $("#dialog-form")

            $.post({
               /// ...
               $this.dialog('close'); // <-- used here
            });
        }       
    }
});
于 2013-03-19T14:18:58.887 回答
10

当您通过调用该.dialog(options)方法初始化对话框时,会创建一个新对话框,但它与您要转换为对话框的原始 div 无关(示例代码中的“#dialog-form”)。该dialog(options)函数返回包含对话数据的元素。所以,如果你这样做:

var myDialog = $("#dialog-form").dialog(options);

然后,您可以像这样调用 open 方法:

myDialog.dialog('open');

如果你想找到包含对话框的元素,它是最接近“ui-dialog-content”类的 div:

var myDialog = $('#dialog-form').closest('div.ui-dialog-content');

对话框数据是uiDialog您查看此元素数据时将看到的数据:

myDialog.data();
于 2013-06-19T13:50:19.360 回答
4

$(this)不是针对 内部的对话框$.post,您需要存储对它的引用。

var self = this; // add this
$.post(..., function(){
    $(self).dialog("close"); // modify this to use self
于 2013-03-19T14:18:38.250 回答
2

我必须执行以下操作才能关闭我的对话框。

 $("#Note").dialog({
        autoOpen: true,            
        modal: true,
        create: function (e, ui) {
          //
        },
        open: function () {
            //
        },            
        buttons: {
                //
                $(".ui-dialog-titlebar-close").trigger('click');
            }
        }
    });
于 2016-03-14T04:43:45.527 回答
0

可能导致此错误的另一件事是,如果出于任何原因您在对话框上调用 removeData()。显然 jquery data() 函数用于初始化对话框,因此如果出于任何原因删除了数据,对话框将不会认为它已被初始化。

当我使用 data() 函数将表单数据存储在对话框对象中,然后在关闭对话框之前在对话框上调用 removeData() 时,我发现了这一点。

于 2014-01-03T01:50:08.700 回答
0

您可能使用了弹出窗口而不是对话框。我认为关闭两者的方法是不同的。尝试使用$("#popid").popup('close');

于 2014-06-23T17:12:03.257 回答