这可能是一个重复的问题,我道歉。我有一个jsp页面,其中有一些按钮。每个按钮都有自己的servlet来调用。我想知道是否有任何方法可以在不使用表单的情况下调用这些servlet,因为用户可以选择给出的3个功能中的任何一个。我还需要将一个值从jsp页面传递给我调用的servlet。
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Configurations</title>
<script type="text/javascript">
function runConfiguration(){
var config=${dataValues.get(0)};
//call servlet
}
function editConfiguration(){
var config=${dataValues.get(0)};
//call servlet
}
function deleteConfiguration(){
var config=${dataValues.get(0)};
//call servlet
}
</script>
</head>
<body>
<%
String[] label={"Master Port","Baud Rate","Char Size","Stop Bits","Parity","RTU Port","Baud Rate","Char Size","Stop Bits", "Parity"};
int i=0;
%>
<br>
<br>
<br>
<table align="center" border="1">
<td><div align="center" style="background-color: goldenrod;"><b> ${dataValues.get(0)}</b></div>
<table width="210" align="left" border="1">
<td bgcolor="goldenrod"><b> Header1 </b></td>
<c:forEach var="data" begin="1" end="5" items="${dataValues}" varStatus="status">
<tr>
<td><%=label[i++]%>: ${data}</td>
</tr>
</c:forEach>
</table>
<table width="210" align="left" border="1">
<td bgcolor="goldenrod"><b> Header2 </b></td>
<c:forEach var="data" begin="6" end="10" items="${dataValues}" varStatus="status">
<tr>
<td><%=label[i++]%>: ${data}</td>
</tr>
</c:forEach>
</table>
</td>
</table>
<c:choose>
<c:when test="${dataValues.get(11)==1}">
<p align="center"><b><i>This configuration is already running</i></b></p>
<p align="center">
<input type="button" value="stop" onclick="StopConfiguration"/>
</p>
</c:when>
<c:otherwise>
<p align="center"><b><i>This configuration is currently NOT running</i></b></p>
<p align="center">
<button type="button" onclick="runConfiguration()">Run</button>
<button type="button" onclick="editConfiguration()">Edit</button>
<button type="button" onclick="deleteConfiguration()">Delete</button>
</p>
</c:otherwise>
</c:choose>
</body>
</html>
答案 0 :(得分:3)
我在这里看到两个选项:
在发送POST请求之前,使用JavaScript相应地更改表单的URL;
对所有3种情况使用表单和相同的servlet。在servlet中,您应该确定按下了什么按钮(它们的值作为请求参数传递)然后相应地前进。
答案 1 :(得分:0)
您可以使用Ajax执行此操作或更糟糕但可运行的方式,您可以更改当前窗口网址并重新加载页面。
对于Ajax调用,我建议您使用ExtJS。见Ext.Ajax Usage
答案 2 :(得分:0)
请在JSP&amp;中指定操作字符串。在你的servlet中检查它。
根据该字符串操作,您可以在servlet代码中设置条件,以确定要执行特定操作的操作。 请看下面这是我在我的代码中所做的。
例如
<A href="<%=request.getContextPath()%>/JobAction?action=runConfig">RUN</a>
<a href="<%=request.getContextPath()%>/JobAction?action=editConfig">EDIT</a>
您可以只调用一个servlet,而不是调用多个servlet。 在servlet中使用这样的代码。
String action = request.getParameter("action");
if (action.equalsIgnoreCase("runConfig")) {
// Specify what you want to do
} else if (action.equalsIgnoreCase("editConfig")) {
// Specify what you want to do
} else if (action.equalsIgnoreCase("deleteConfig")) {
// Specify what you want to do
}
答案 3 :(得分:0)
您也可以使用Javascript,当用户点击按钮时调用脚本并动态更改网址并提交该表单。
这是一个例子.....
<form action = "something".....>
your stuff here....
<button type="button" onclick="runConfiguration(actionName)">Run</button>
<button type="button" onclick="editConfiguration(actionName)">Edit</button>
<button type = "button" onclick = "deleteConfiguration(actionName)">Delete</button>
并在你的脚本中
<script type="text/javascript">
function runConfiguration(actionName){
var config=${dataValues.get(0)};
goToPage(actionName);
//call servlet
}
function editConfiguration(actionName){
var config=${dataValues.get(0)};
goToPage(actionName)
//call servlet
}
function deleteConfiguration(actionName){
var config=${dataValues.get(0)};
goToPage(actionName)
//call servlet
}
function gotopage(actionname)
{
document.formName=actionname;
document.formName.submit();
}
</script>
答案 4 :(得分:-1)
你可以使用这个:
<a href="<%=request.getContextPath()%>/logout"> Logout </a>
如果你想给它添加一些引导程序,你所要做的就是
<a href="<%=request.getContextPath()%>/logOut">
<button class="btn btn-outline-secondary" type="button">log out </button>
</a>