jQuery UI 对话框不会第二次打开,但无法访问后台



对话框是用JSTL foreach tag生成的。

我第一次尝试打开对话框

(其中任何一个)时,它会正常打开,但是第二次尝试打开它时,背景变为灰色并且由于对话框是模式而无法访问,但对话框窗口未显示。

这个问题有很多问题,我通读了很多,但据我了解,没有一个描述这种情况。

这是我的 HTML:

<button id="buttonAddTask${category.id}" class="buttonAddTask">Add Task</button>
...
<div id="dialog${category.id}" title="Create new task" class="task-dialog">
<form:form id="taskForm${category.id}"
    action="${contextPath}/someAction"
     method="POST" modelAttribute="someAttribute">
     <fieldset>
        <form:input type="text" path="taskName" id="taskName" 
             class="text ui-widget-content ui-corner-all" />
        <form:textarea rows="4" path="taskDescription"
                 id="taskDescription" name="taskDescription"
                 class="text ui-widget-content ui-corner-all">
        </form:textarea>
    </fieldset>
</form:form>
</div>

这是我的js代码:

$(function() {
    var form;
    var taskDialog = $(".task-dialog");
    var buttonAddTask = $(".buttonAddTask");
taskDialog.dialog({
    autoOpen : false,
    height : 500,
    width : 415,
    modal : true,
    buttons : {
        "Create task" : addTask,
        Cancel : function() {
            taskDialog.dialog("close");
        }
    },
    close : function() {
        var form = $(this).find("form")[0].reset();
        allFields.removeClass("ui-state-error");
        }
    });
    function addTask() {
        var thisId = $(this).attr("id").substring(6, 106);
        $("#taskForm" + thisId).submit();
        return true;
    }
buttonAddTask.on("click", function() {
        var thisId = $(this).attr("id");
        var idNumber = thisId.substring(13, 14);
        $("#dialog" + idNumber).dialog("open");
    });
});

我用.dialog("打开")打开对话框,然后关闭它。对话框是通过 id 选择器访问的,因此在移动到正文标签的末尾后,它应该是可访问的。我做错了什么,或者我必须做什么才能第二次显示对话框?

我正在使用jQuery 2.1.1

和jQuery-ui 1.11.2。

了一会儿我明白了。

这是从某个示例中复制/粘贴的,并且经过修改以满足我的需求。诀窍是在关闭函数中删除未声明的变量"allFields"。

要删除的行:

allFields.removeClass("ui-state-error");

如果您有类似的问题,请检查关闭函数中是否存在未声明的变量,并删除它们。

最新更新