所以,这就是我想要实现的目标。假设我有一个表单,我填写详细信息并单击提交。数据将插入数据库。现在,我的想法是,我想使用ajax显示刚刚添加到数据库的数据,而无需刷新页面。我正在学习使用ajax的想法,所以我有点迷失。有人可以建议任何建议。 我的想法是,当我点击提交时,将会触发两个事件。一种是将数据插入数据库,另一种是从数据库获取数据并将其显示在标记内。
这是我的servlet中的get方法。 Home.java
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
PrintWriter out = response.getWriter();
response.setContentType("text/html");
out.println("<html><body>");
try {
Class.forName("com.mysql.jdbc.Driver");
Connection con= (Connection) DriverManager.getConnection("jdbc:mysql://localhost/apiprovider","root","");
Statement stmt = con.createStatement();
ResultSet rs = stmt.executeQuery("select * from apiinfo");
// out.println("<table border=1 width=50% height=50%>");
// out.println("<tr><th>EmpId</th><th>EmpName</th><th>Salary</th><tr>");
while (rs.next()) {
String n = rs.getString("apiname");
String nm = rs.getString("apiendpoint");
int s = rs.getInt("id");
response.getWriter().write(n);
// out.println("<tr><td>" + n + "</td><td>" + nm + "</td><td>" + s + "</td></tr>");
}
// out.println("</table>");
// out.println("</html></body>");
con.close();
}
catch (Exception e) {
out.println("error");
}
}
回到Home.jsp
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>Insert title here</title>
</head>
<body>
<div id="ajaxresponse">
</div>
<form>
API Name:<br>
<input type="text" id = "apiname" name="apiname">
API ENDPOINT:<br>
<input type="text" id ="apiendpoint" name="apiendpoint">
<br>
API VERSION:<br>
<input type="text" id="apiversion" name="apiversion">
ACCESSIBLE:<br>
<input type="checkbox" name="source" value="internet"> Internet<br>
<input type="checkbox" name="source" value="vpn"> VPN<br>
<br><br>
<input type="submit" formaction="Home" method="post" value="Submit">
<br>
<input type="submit" name="Submit" value="Submit">
</form>
<script src="https://code.jquery.com/jquery-3.2.1.min.js"></script>
<script type="text/javascript">
$(document).ready(function() {
$('#Submit').click(function(event) {
console.log("You clicked me");
$.ajax({
url: "Home",
sucess:function(result){
}
});
});
});
</script>
</body>
</html>
答案 0 :(得分:0)
我认为你不需要举办两场比赛。您应该向servlet发送ajax调用并从中获取格式正确的JSON(来自DB的数据)。在这种情况下,当您收到数据时,您知道插入成功。在你的sucess
函数之后,你需要解析来自servlet的响应并使用javaScrip set数据到你表单的元素。
答案 1 :(得分:0)
您可以根据故障转移情况以多种方式实现此目标
请通过此链接更好地了解ajax with servlets.
如果此次调用成功,则单击“提交”按钮首先将数据插入数据库然后再触发一次ajax调用以从数据库中获取数据以显示请在下方检查sudo代码
<script type="text/javascript">
$(document).ready(function() {
$('#Submit').click(function(event) {
console.log("You clicked me");
$.ajax({
url: "Home",
sucess:function(result){
// here call another servlet which will get the data
}
});
});
});
</script>
如果插入调用失败,您可以提及诸如“插入失败,请稍后再试”的通用消息