在 JSP 上使用 Jquery Ajax 在数据表上显示



这是我第一次使用 Jquery Ajax。

上下文是,我正在尝试在Datatable上显示超过10000行数据,我以前所做的只是使用我的servlet将数据的Arraylist转发到JSP,然后循环并将数据显示到显示数据上。

加载数据表花费太多时间。所以我决定尝试使用 Jquery Ajax 看看这是否有助于解决这个问题。

我目前在实施它时面临一些问题,有人可以帮助我吗?

我正在使用 GSON 来序列化我的数组列表。

奴仆.java

String json =  gson.toJson(listS);
...
request.setAttribute("listS", json);
request.getRequestDispatcher("WEB-INF/index.jsp").forward(request, response);

索引.jsp

String list =  (String) request.getAttribute("listStartup");
......
<td>Insert 1st Element</td>
<td>Insert 2nd Element</td>
<%
};
......

<script>
$(function () {
<% list =  (String) request.getAttribute("listS");%> 
$("#sp").DataTable({
"scrollY": 500,
"scrollX": true,
"paging": true,
"lengthChange": false,
"searching": true,
"ordering": true,
"info": true,
"autoWidth": false,
"processing": true,
"serverSide": true,
"ajax" : list
});
});

</script>

我的 JSON 数组结构是这样的,这是输出

[
{
"Element1": "Text",
"Element2": "Text",
},
{
"Element1": "Text",
"Element2": "Text",
},
....
]

如果有人愿意将我链接到一些我可以通读的有用文档。我现在似乎找不到任何对我有帮助的东西。

我不确定如何遍历我的 JSONarray 以访问对象并显示我的 JSON 数据。 如果有 1000 个对象,我将遍历每个对象并连续显示它们的数据。

我也不知道如何让它与数据表一起使用......

你得到的是json数组,其中每个json对象都有一些特定的键(Element1和Element2(。您只需要将这些键映射到数据表中的相应列即可。然后将列表传递给数据表进行呈现。

请参阅下面的代码

$(function () {
var list = <% (String) request.getAttribute("listS");%>;
//convert string to json object
var listJson = JSON.parse(list);
var table = $("#sp").DataTable({
"scrollY": 500,
"scrollX": true,
"paging": true,
"lengthChange": false,
"searching": true,
"ordering": true,
"info": true,
"autoWidth": false,
"columns": [ // map the columns here
{ "data": "Element1" },
{ "data": "Element2" }
]
});
//render list here
table.clear();
table.rows.add(listJson); // make sure that list should be json object and not text
table.draw();
});

最新更新