所以我有一个函数可以通过 AJAX 提交内容,然后如果成功与否则显示一个对话框。一切正常,但是我希望选择向该对话框函数传递一个额外的函数(可选),该函数将执行额外的功能。这是我所拥有的:
// the work
if (data._response.success == 'true') {
$("#suppliers_grid").trigger("reloadGrid");
$('#manage-suppliers-form').fullFormReset();
alertDialog('Supplier '+ action +' successfully!','Success',$('#manage-suppliers-form :input:visible:first').focus());
} else {
alertDialog('Supplier was not '+ action +' successfully!<br />Please try again or report this to the administrator.','Error','ui-state-error');
}
// the alertDialog function
function alertDialog(message,title,cssClass,closeFunction) {
title = typeof title !== 'undefined' ? title : 'Notice';
cssClass = typeof cssClass !== 'undefined' ? cssClass : 'ui-state-highlight';
if (cssClass=='ui-state-error') {
icon = 'ui-icon-alert';
}
else {
icon = 'ui-icon-info';
}
var dialog = $('<div><p><span class="ui-icon '+ icon +'"></span>'+ message +'</p></div>');
dialog.dialog({
modal: true,
title: title,
buttons: {
Ok: function() { $(this).dialog("close"); }
},
close: closeFunction()
});
}
1)如果我通过 closeFunction 上述方法不起作用
2) 甚至没有测试过它——没有传递一些东西,但我相信它也不会工作。closeFunction 应该是可选的
3)我不能简单地将“焦点”代码行放在 alertDialog 调用之后。即使这有效(在后台获得焦点)。一旦有人在alertDialog上单击“确定”,焦点就会丢失-因此需要在alertDialog关闭时调用。