public String getModules(int todo, int offset, int pageSize, int total,
int moduleNo) {
total = getAllModules(todo, 0, 1, moduleNo).getTotal();
int maxPage = total % pageSize == 0 ? total / pageSize : total
/ pageSize + 1;
if (offset < 0) {
offset = 0;
} else if (offset >= maxPage) {
offset = maxPage - 1;
}
PageModel pm = getAllModules(todo, offset * pageSize, pageSize,
moduleNo);
List<Menu> list = pm.getDatas();
JSONObject json = new JSONObject();// json父对象
try {
// json集合,用来存储json对象
JSONArray members = new JSONArray();
if (list != null && list.size() > 0) {
for (int i = 0; i < list.size(); i++) {
// json子对象
JSONObject member = new JSONObject();
member.put("menuId", list.get(i).getMenuId());
member.put("menuNo", list.get(i).getMenuNo());
member.put("parentNo", list.get(i).getParentNo());
member.put("menuName", list.get(i).getMenuName());
member.put("linkURL", list.get(i).getLinkURL());
member.put("description", list.get(i).getDescription());
members.add(i, member);
}
json.put("offset", offset);// 存储当前页===从0开始
json.put("maxPage", maxPage - 1);// 存储最大页数
json.put("total", total);// 存储所有显示条数
json.put("menus", members);// 存储数据
}
} catch (Exception e) {
e.printStackTrace();
}
return json.toString();
}
以上代码方法为从数据库查询,并用json进行封装。
下面代码介绍json的显示:
function jsonview() { var total = $("total1").innerHTML; var offset = $("offset1").value; var pageSize = 5; menuDao.getModules(1,offset, pageSize, total, wirteHtml); } function wirteHtml(data) { var data = eval("(" + data + ")");// 使用eval函数 var continents = data.menus; $("offset1").value = data.offset; $("maxPage1").value = data.maxPage; $("maxPage2").innerHTML = data.maxPage + 1; $("total1").innerHTML = data.total; $("curpage").innerHTML = data.offset + 1; var tab = $("mytables"); var num = tab.rows.length; for ( var i = 0; i < num; i++) { if (tab.rows.length != 2) { tab.deleteRow(tab.rows.length - 2); } } for ( var i = 0; i < continents.length; i++) { var newLine = tab.rows.length; var row = tab.insertRow(newLine - 1); if (i % 2 != 0) { row.className = "odd";// 奇数行 row.onmouseout = function() { this.className = "odd"; } } else { row.className = "even";// 偶数行 row.onmouseout = function() { this.className = "even"; } } row.onmouseover = function() { this.className = "alt"; } row.insertCell(0).innerHTML = "<input style=\"width:20px;\" type=\"radio\" name=\"rdoId\" value=\"" + continents[i].menuNo+ "\" title=\""+ continents[i].menuName+ "\" />"; row.insertCell(1).innerHTML = continents[i].menuNo; row.insertCell(2).innerHTML = continents[i].menuName + ""; if(continents[i].description==''){ row.insertCell(3).innerHTML = '暂无说明'; } else{ row.insertCell(3).innerHTML = continents[i].description; } } }