0
我在使用ajax追加内容div时遇到了问题。该servlet的响应将打印两次。来自servlet的Ajax响应正在打印两次
这是两个页面的代码。
demo.jsp
<html>
<head>
<script>
function run()
{
var content = document.getElementById("output");
var xhr = new XMLHttpRequest();
xhr.onreadystatechange = function() {
content.innerHTML += xhr.responseText;
}
xhr.open("POST", "demo", true);
xhr.send(null);
}
</script>
</head>
<body>
<input type="submit" value="Add Content" onclick="run();"/>
<div id="output">This is Static Text.</span><br>
</div>
</body>
DemoServlet
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
@WebServlet(urlPatterns = {"/demo"})
public class Demo extends HttpServlet {
protected void processRequest(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setContentType("text/html;charset=UTF-8");
PrintWriter out = response.getWriter();
try {
/* TODO output your page here. You may use following sample code. */
out.println("This is Dynamic Text<br>");
} finally {
out.close();
}
}
}
的输出 div的最终含量是:
这是静态文本。
这是动态文本。
这是动态文本。
我无法理解动态文本为什么要打印两次。
在此先感谢。
如果你究竟了解如何使用'XMLHttpRequest'?我建议重新阅读该资源或寻找更好的资源。 – BalusC 2013-05-08 19:39:10