2013-05-08 16 views
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的最终含量是:

这是静态文本。

这是动态文本。

这是动态文本。

我无法理解动态文本为什么要打印两次。

在此先感谢。

+0

如果你究竟了解如何使用'XMLHttpRequest'?我建议重新阅读该资源或寻找更好的资源。 – BalusC 2013-05-08 19:39:10

回答