上篇博客论述了,数据库查询数据返回前台JSP。博客中主要使用Ajax调用来显示JSON串,来获取其中某一个字段,赋给界面中的某一个控件。

那这篇博客中,我们讲解,把后台List传递JSP展示。

List传递界面,以前我们普通的做法是怎么样的呢?foreach 的el表达式?还是java代码?

那对于本身就是Json格式的list,到底如何显示呢?

显然表单中的el表单以及java代码不合适。那我们继续使用Ajax来显示。

一:对于不使用前台框架的情况:就是咱们普通的table,到底如何以表格的形式显示list呢?

OK,方案如下:动态生成表格。

js代码如下:demo中使用某个按钮触发,当然可以在body初始化$(function(){//动态生成表格});各自所需哈。

我把table嵌套在div中:

<body>
<input type="button" value="用ajax测试具体数据" onclick="testajax()" />
<div id="testtable"></div>
</body>

testajax() js如下:

	function testajax() {
var _url = "http://localhost:8080/testmongodb/mongodb/";
jQuery.ajax({
url : _url,
type : "get",
dataType : "json",
success : function(d) {
alert(JSON.stringify(d));
//动态生成table
var mongotable=$("<table border=\"1\"></table>");
mongotable.appendTo("#testtable");
for(var o in d){
//生成tr,添加到table中
var tr=$("<tr></tr>");
tr.appendTo(mongotable);
//生成td
var td_id=$("<td width=\"150\">"+d[o].id+"</td>");
var td_name=$("<td width=\"150\">"+d[o].name+"</td>");
var td_city=$("<td width=\"150\">"+d[o].address.city+"</td>");
var td_code=$("<td width=\"150\">"+d[o].address.code+"</td>"); //把td添加到tr中
td_id.appendTo(tr);
td_name.appendTo(tr);
td_city.appendTo(tr);
td_code.appendTo(tr);
}
alert($("#testtable").html());
}
});
}

至于样式,大家可以根据自己需求在js添加哈。

后台的list如下:

[{ "_id" : { "$oid" : "52564aa6b16b9c6f728c0cf8"} , "id" : 1 , "name" : "小明" , "address" : { "city" : "beijing" , "code" : "065000"}}, { "_id" : { "$oid" : "52566683b16be14866e9bdc5"} , "id" : 2 , "name" : "小红" , "address" : { "city" : "beijing" , "code" : "065000"}}]

页面如下:

二:使用前台框架:举例,ligerui中的grid展示:(前提:把js、css已经引入)

grid代码如下:

	$(function() {
$("#test").ligerGrid({
columns:[
{display:'id',name:'id',width:'200'},
{display:'名称',name:'name',width:'200'},
{display:'城市',name:'address.city',width:'250'},
{display:'邮编',name:'address.code',width:'250'}
],
rownumbers : true,
width:'80%',
height:'150',
url:'http://localhost:8080/testmongodb/mongodb/'
});
});

其中的test是div的id:

<body>
<input type="button" value="用ajax测试具体数据" onclick="testajax()" />
<!-- 测试grid,多行数据 -->
<div id="test"></div>
</body>

但是你会发现,即使后台显示数据,但是grid竟然无法显示。为啥呢?

那肯定是grid显示数据源格式与给出的json的list格式不匹配。

这是ligerui中grid的特有的,看相应的api会发现,grid的数据源data默认的数据格式,是{Rows:[]}

但是咱们后台的List格式如下:

[{ "_id" : { "$oid" : "52564aa6b16b9c6f728c0cf8"} , "id" : 1 , "name" : "小明" , "address" : { "city" : "beijing" , "code" : "065000"}}, { "_id" : { "$oid" : "52566683b16be14866e9bdc5"} , "id" : 2 , "name" : "小红" , "address" : { "city" : "beijing" , "code" : "065000"}}]

那只要在前面加上Rows:即可,在js模拟此data

var data={Rows:[{"_id":{"inc":1921780984,"machine":-1318347665,"new":false,"time":1381386918000,"timeSecond":1381386918},"id":1,"name":"小明","address":{"city":"beijing","code":"065000"}},{"_id":{"inc":1726594501,"machine":-1318330040,"new":false,"time":1381394051000,"timeSecond":1381394051},"id":2,"name":"小红","address":{"city":"beijing","code":"065000"}}]}
$(function() {
$("#test").ligerGrid({
columns:[
{display:'id',name:'id',width:'200'},
{display:'名称',name:'name',width:'200'},
{display:'城市',name:'address.city',width:'250'},
{display:'邮编',name:'address.code',width:'250'}
],
rownumbers : true,
width:'80%',
height:'150',
data:data
// url:'http://localhost:8080/testmongodb/mongodb/'
});
});

结果如下:

当然可以获取data,然后在此基础上拼串{Rows:[]}

当然也可以在返回前台Response中,拼接Rows

package com.mongo.servlet;
import java.io.IOException;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import net.sf.json.JSONArray;
import net.sf.json.JSONObject;
import com.mongo.dao.EntityTest;
public class EntityServlet extends HttpServlet { @Override
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
System.out.println("doget.....");
try {
List list=new EntityTest().selectAll();
response.setCharacterEncoding("UTF-8");
//主要用于ligerui的grid形式,默认是rows
initJsonList(request,response,list);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
} }
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
// TODO Auto-generated method stub
doGet(req, resp);
}
protected void initJsonList(HttpServletRequest request,
HttpServletResponse response, List list) {
Map map = new HashMap();
map.put("Rows", list);
JSONObject jsonObject = JSONObject.fromObject(map);
try {
response.setCharacterEncoding("utf-8");
response.getWriter().write(jsonObject.toString());
System.out.println(jsonObject);
} catch (IOException e) {
System.out.println(e.toString());
}
}
}

使用JSONObject对象进行转化。

对于其他非ligerui的展示,其实不必使用JSONObject或JSONArray进行转换,因为本身就是JSON格式。

当然转换也是没有坏处的,只不过转化后格式所有不同而已,但是不影响,因为用户的属性是不会改变的,影响的是mogodb中特有的_id的属性。

{"Rows":[{"_id":{"inc":1921780984,"machine":-1318347665,"new":false,"time":1381386918000,"timeSecond":1381386918},"id":1,"name":"小明","address":{"city":"beijing","code":"065000"}},{"_id":{"inc":1726594501,"machine":-1318330040,"new":false,"time":1381394051000,"timeSecond":1381394051},"id":2,"name":"小红","address":{"city":"beijing","code":"065000"}}]}

OK,到此为止,某一个字段以及表格形式的基本功能实现方式已经叙述。

这两篇博客的项目,是用一个项目,只不过各种方式演示,通过注释来完成。

在此提示:若非ligerui,直接使用数组形式而已[],不要使用Rows:[]格式。但是对于其他的框架,比如ext,easyui,他们都有自己的数据源格式,但是肯定的是,后台依然是JSON串。

项目Demo,点我下载

mongodb基础系列——数据库查询数据返回前台JSP(二)的更多相关文章

  1. mongodb基础系列——数据库查询数据返回前台JSP(一)

    经过一段时间停顿,终于提笔来重新整理mongodb基础系列博客了. 同时也很抱歉,由于各种原因,没有及时整理出,今天做了一个demo,来演示,mongodb数据库查询的数据在JSP显示问题. 做了一个 ...

  2. laravel 查询数据返回的结果

    laravel查询数据返回的结果 在插入数据库的时候,发现查询数据返回的结果是一个对象;即使是空数据 返回的不是true或者false 那么要判断该结果是否查询有结果 该如果呢? 学习源头: http ...

  3. C#连接Oracle数据库查询数据

    C#连接Oracle数据库可以实现许多我们需要的功能,下面介绍的是C#连接Oracle数据库查询数据的方法,如果您对C#连接Oracle数据库方面感兴趣的话,不妨一看. using System; u ...

  4. 用struts2标签如何从数据库获取数据并在查询页面显示。最近做一个小项目,需要用到struts2标签从数据库查询数据,并且用迭代器iterator标签在查询页面显示,可是一开始,怎么也获取不到数据,想了许久,最后发现,是自己少定义了一个变量,也就是var变量。

    最近做一个小项目,需要用到struts2标签从数据库查询数据,并且用迭代器iterator标签在查询页面显示,可是一开始,怎么也获取不到数据,想了许久,最后发现,是自己少定义了一个变量,也就是var变 ...

  5. 在使用Ibatis查询数据返回时,报如下错误:java ibatis The error happened while setting a property on the result object

    问题: 在使用Ibatis查询数据返回时,报如下错误: [com.show.add.proxy.SqlMapClientTemplateProxy]com.ibatis.common.jdbc.exc ...

  6. koa 基础(二十一)nodejs 操作mongodb数据库 --- 查询数据

    1.app.js /** * nodejs 操作mongodb数据库 * 1.安装 操作mongodb * cnpm install mongodb --save * 2.引入 mongodb 下面的 ...

  7. Mongodb基础用法及查询操作[转载]

    插入多条测试数据> for(i=1;i<=1000;i++){... db.blog.insert({"title":i,"content":&qu ...

  8. Mongodb基础用法及查询操作

    插入多条测试数据> for(i=1;i<=1000;i++){... db.blog.insert({"title":i,"content":&qu ...

  9. [转]C#反射,根据反射将数据库查询数据和实体类绑定,并未实体类赋值

    本文来自:http://www.cnblogs.com/mrchenzh/archive/2010/05/31/1747937.html /****************************** ...

随机推荐

  1. 自己动手实现STL:前言

    一.前言 最近,刚看完<STL源码剖析>,深深被实现STL库的那些的大牛们所折服.同时又感觉自己与大牛们差距之大,便萌生深入学习之意.如果仅仅只是看看<STL源码剖析>的话,又 ...

  2. bzoj1601: [Usaco2008 Oct]灌水

    经典延伸最小生成树问题... #include<cstdio> #include<cstring> #include<cctype> #include<alg ...

  3. Discuz 5.x/6.x/7.x投票SQL注入分析

    看乌云有人爆了这个漏洞:http://www.wooyun.org/bugs/wooyun-2014-071516感觉应该是editpost.inc.php里投票的漏洞.因为dz已经确定不会再修补7. ...

  4. Lost connection to MySQL server at 'reading initial communication packet' 错误解决

    Lost connection to MySQL server at 'reading initial communication packet' 错误解决 上次解决了这个问题,今天又碰到,突然失忆, ...

  5. UVA 11865 Stream My Contest(最小树形图)

    题意:N台机器,M条有向边,总资金C,现要到搭建一个以0号机(服务器)为跟的网路,已知每条网线可以把数据从u传递到v,其带宽为d,花费为c,且d越大,传输速度越快,问能够搭建的传输速度最快的网络d值是 ...

  6. [反汇编练习] 160个CrackMe之008

    [反汇编练习] 160个CrackMe之008. 本系列文章的目的是从一个没有任何经验的新手的角度(其实就是我自己),一步步尝试将160个CrackMe全部破解,如果可以,通过任何方式写出一个类似于注 ...

  7. centos使用denyhosts的问题,会将自己的IP自动加到hosts.deny的解决办法。

    先吐槽, 很多网站\博客,技术文章也玩伪原创, 害人不浅. 全TMD是COPY, COPY, COPY过来. 拷过来就算了, 你TMD还改了其中的内容... 改成错的.然后众多网站转载, 将错进行到底 ...

  8. mysql 索引与优化like查询

    索引与优化like查询 1. like %keyword    索引失效,使用全表扫描.但可以通过翻转函数+like前模糊查询+建立翻转函数索引=走翻转函数索引,不走全表扫描. 2. like key ...

  9. MVC&WebForm对照学习:ajax异步请求

    写在前面:由于工作需要,本人刚接触asp.net mvc,虽然webform的项目干过几个.但是也不是很精通.抛开asp.net webform和asp.net mvc的各自优劣和诸多差异先不说.我认 ...

  10. MyBatis 如何接收参数

    MyBatis的mapper接口不需要自己实现,框架会自动帮我们实现,到时候直接调用就可以了.定义的mapper接口中的方法可以有多个参数吗?答案是肯定.在Ibatis时代是自己通过代码实现如何调用x ...