Handling servlet output in AJAX

前端 未结 1 1506
臣服心动
臣服心动 2020-12-08 05:46

My problem: I am sending a request to a servlet from an AJAX function in a JSP.

The servlet processes the data and returns a ArrayList.

My quest

相关标签:
1条回答
  • 2020-12-08 06:44
    var profileXML = eval(<%=request.getAttribute("data")%>);
    

    Firstly, I would recommend you to learn about the wall between JavaScript and JSP. JS runs entirely at the client side and JSP/Java runs entirely at the server side. They certainly doesn't run in sync as you seem to think. To learn more, read this blog article.

    function ajaxFunction ( )
    

    Secondly, I would recommend you to use an existing, robust, thoroughly-developed, well-maintained JavaScript library with Ajaxical capabilities such as jQuery instead of reinventing the AJAX wheel and fighting/struggling/worrying with browser specific issues/troubles/behaviors/pains. I would also recommend to use JSON as data transfer format between Java Servlet at server and JavaScript at client. In the Java side you can use the great Gson library for this.

    Here's a kickoff example with all of the mentioned techniques. Let's start with a Servlet and a JavaBean:

    public class JsonServlet extends HttpServlet {
        protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            List<Data> list = dataDAO.list();
            response.setContentType("application/json");
            response.setCharacterEncoding("UTF-8");
            response.getWriter().write(new Gson().toJson(list));
        }
    }
    
    public class Data {
        private Long id;
        private String name;
        private Integer value;
        // Add/generate getters/setters.
    }
    

    The JsonServlet (you may name it whatever you want, this is just a basic example) should be mapped in web.xml on a known url-pattern, let's use /json in this example. The class Data just represents one row of your HTML table (and the database table).

    Now, here's how you can load a table with help of jQuery.getJSON:

    $.getJSON("http://example.com/json", function(list) {
        var table = $('#tableid');
        $.each(list, function(index, data) {
            $('<tr>').appendTo(table)
                .append($('<td>').text(data.id))
                .append($('<td>').text(data.name))
                .append($('<td>').text(data.value));
        });
    });
    

    The tableid of course denotes the idof the <table> element in question.

    That should be it. After all it's fairly simple, believe me. Good luck.

    0 讨论(0)
提交回复
热议问题