Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/364.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 如何在上下文菜单中单击选项时显示模式对话框?_Javascript_Jquery_Jsp_Modal Dialog_Contextmenu - Fatal编程技术网

Javascript 如何在上下文菜单中单击选项时显示模式对话框?

Javascript 如何在上下文菜单中单击选项时显示模式对话框?,javascript,jquery,jsp,modal-dialog,contextmenu,Javascript,Jquery,Jsp,Modal Dialog,Contextmenu,当我从一个上下文菜单中选择一个选项配置选项时,需要弹出一个模式对话框,该菜单源于jsplumb流程图组件内部。我有userlogged.jsp,它是流程图组件出现的地方。demo.js是上下文菜单函数所在的位置。jsp有一个模式,我需要显示在userLogged.jsp内容的顶部 这是demo.js的一部分 $(function() { $.contextMenu({ selector : '.context-menu-one', cal

当我从一个上下文菜单中选择一个选项配置选项时,需要弹出一个模式对话框,该菜单源于jsplumb流程图组件内部。我有userlogged.jsp,它是流程图组件出现的地方。demo.js是上下文菜单函数所在的位置。jsp有一个模式,我需要显示在userLogged.jsp内容的顶部

这是demo.js的一部分

   $(function() {
     $.contextMenu({
          selector : '.context-menu-one',
           callback : function(key, options) {
              $(document)
        .ready(
                function() {
                    fromMenu();

                });
              if (key == "configure") {

                  fromMenu();
              }
       },
       items : {
              "configure" : {
                     name : "configure",
                     icon : "edit"
              },
              "delete" : {
                     name : "Delete",
                     icon : "delete"
              }
          }
       });
    });
这是index.jsp

    <%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>

       <!doctype html>
        <!--[if IE 9]><html class="lt-ie10" lang="en" > <![endif]-->
       <html class="no-js" lang="en"
data-useragent="Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.2; Trident/6.0)">
        <head>
        <meta charset="utf-8" />
         <meta name="viewport" content="width=device-width, initial-scale=1.0" />

          <meta name="description"
content="Documentation and reference library for ZURB Foundation. JavaScript, CSS, components, grid and more." />
           <meta name="author"
content="ZURB, inc. ZURB network also includes zurb.com" />
           <meta name="copyright" content="ZURB, inc. Copyright (c) 2015" />
            <link rel="stylesheet" href="src/css/foundation.css" />
           <script src="src/js/modernizr.js"></script>
           <script src="src/js/jquery.js"></script>
           <script type="text/javascript">
        $(document)
        .ready(
                function() {

                    $('#firstModal').foundation('reveal', 'open');

                    //checks for the button click event
                    $("#sec")
                            .click(
                                    function(e) {
                                        var username = $("input#username")
                                                .val();
                                        var root = $("input#root").val();
                                        var password = $("input#password")
                                                .val();
                                        var db = $("input#db").val();
                                        var port = $("input#port").val();
                                        dataString = "username=" + username
                                                + "&root=" + root
                                                + "&password=" + password
                                                + "&db=" + db + "&port="
                                                + port;
                                        $.ajax({
                                                    type : "GET",
                                                    url : "DbInformation",
                                                    data : dataString,
                                                    success : function(data) {
                                                        var data = JSON.parse(data);
                                                        alert(data);
                                                        console.log(data.length);
                                                        $("#countrytable").find("tr:gt(0)").remove();
                                                        var table1 = $("#countrytable");
                                                        for ( var i = 0; i < data.length; i++) {
                                                            var rowNew = $("<tr><td></td></tr>");
                                                            rowNew.children().eq(0).html(("<select id='tabl'  name=mytextarea size=3 height = '20px' ><option name=one value="+data[i]+">"+ data[i] + "</option></select>"));
                                                            rowNew.appendTo(table1);
                                                        }
                                                    }
                                                });
                                    });
                    $("#third").click(
                            function(e) {
                                var tabl = $("#tabl").val();
                                var username = $("input#username").val();
                                var root = $("input#root").val();
                                var password = $("input#password").val();
                                var db = $("input#db").val();
                                var port = $("input#port").val();
                                dataString = "username=" + username
                                        + "&root=" + root + "&password="
                                        + password + "&db=" + db + "&port="
                                        + port + "&tabl=" + tabl;
                                $.ajax({
                                    type : "GET",
                                    url : "DbInformation",
                                    data : dataString,
                                    success : function(data) {
                                        var data = JSON.parse(data);
                                        alert(data);
                                        var dd = "";
                                        console.log(data.length);
                                        $("#columns").find("tr:gt(0)").remove();
                                        var table1 = $("#columns");
                                        for ( var i = 0; i < data.length; i++) {
                                            var rowNew = $("<tr><td></td></tr>");
                                            rowNew.children().eq(0).html(("<select id='tabl'  name=mytextarea size=3 height = '20px' ><option name=one value="+data[i]+">"+ data[i] + "</option></select>"));
                                            rowNew.appendTo(table1);
                                        }
                                    }
                                });
                            });
                });
       </script>
       </head>
       <body>



        <div id="firstModal" class="reveal-modal tiny" data-reveal>
            <h2>Properties.</h2>
            <p>
                Username : <input type="text" id="username" name="username"
                    value="">
            </p>
            <p>
                root : <input type="text" id="root" name="root" value="">
            </p>
            <p>
                password : <input type="text" id="password" name="password"
                    value="">
            </p>
            <p>
                db : <input type="text" id="db" name="db" value="">
            </p>
            <p>
                port : <input type="text" id="port" name="port" value="3306">
            </p>
            <p>
                <a href="#" id="sec" data-reveal-id="secondModal"
                    class="secondary button">Next</a>
            </p>
            <a class="close-reveal-modal">&#215;</a>
        </div>

        <div id="secondModal" class="reveal-modal tiny" data-reveal>
            <h2>This is a second modal.</h2>
            <table id="countrytable">
                <tr>
                    <th scope="col">Table name</th>
                </tr>
            </table>
            <p>
                <a href="#" id="third" data-reveal-id="thirdModal"
                    class="third button">Next</a>
            </p>
            <a class="close-reveal-modal">&#215;</a>
        </div>

        <div id="thirdModal" class="reveal-modal tiny" data-reveal>
            <h2>This is a second modal.</h2>
            <table id="columns">
                <tr>
                    <th scope="col">Column name</th>
                </tr>
            </table>
            <p>
                <a href="#" id="fourth" data-reveal-id="thirdModal"
                    class="fourth button">Finish</a>
            </p>
            <a class="close-reveal-modal">&#215;</a>
        </div>




<script src="src/js/foundation.js"></script>
<script src="src/js/foundation.tab.js"></script>
<script src="src/js/foundation.reveal.js"></script>
<script>
    $(document).foundation();
    var doc = document.documentElement;
    doc.setAttribute('data-useragent', navigator.userAgent);
</script>
    </body>
     </html>

如何使index.jsp中生成的模式在demo.js中定义的上下文菜单中单击configure选项时显示在userlogged.jsp的顶部如果您希望模式对话框覆盖userlogged.jsp的内容,那么我认为您应该将模式对话框的代码放在该页面本身中,因为如果它导航到一个单独的页面,比如index.jsp,那么它就不会是一个模式对话框,因为它已经导航到了另一个页面

一种方法是将模态对话框HTML代码放在父页面中,在您的情况下是userlogged.jsp,如果我没有错的话,将其可见性设置为hidden,以便在默认情况下不会显示,并且在触发特定事件(如单击特定上下文菜单)时,将可见性设置为正常,使其在现有页面上显示为模式对话框。 另外,通过将某个事件的可见性设置为“隐藏”(hidden),如单击“模式”对话框上的“确定”(OK)按钮,确保您也注意删除该模式

希望有帮助