Javascript 如何在上下文菜单中单击选项时显示模式对话框?
当我从一个上下文菜单中选择一个选项配置选项时,需要弹出一个模式对话框,该菜单源于jsplumb流程图组件内部。我有userlogged.jsp,它是流程图组件出现的地方。demo.js是上下文菜单函数所在的位置。jsp有一个模式,我需要显示在userLogged.jsp内容的顶部 这是demo.js的一部分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
$(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">×</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">×</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">×</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)按钮,确保您也注意删除该模式 希望有帮助