Jasper report用JSON文件调试预览(附解决JSON报错)

Jasper report用JSON文件调试预览(附解决JSON报错),第1张

比如我要打山尘弊印这个表格的某一行数据

1.先新建好JSON文件(我这是个table的数据,带分页的,row变量就是一行一行的数据,现在测试数据只有一行)

2.然后新建DateAdapter

自己起名字,好了点next

选择JSON File,点next

选择刚才的JSON文件,下面勾选 Use the report JSON expression when filling the report,点Finish(我这已经做过一遍了, 所以Finish是灰的,不用管我这)

DataAdapter创建好了,点下Test Connextion试下对不对

3.创建页面打印模板

纸张就自己选择了,next

命名,继续next

选择刚刚创建的DataAdapter文件,next(这里可能会有JSON  DataAdapter问题,后面补充)

窗口变成这样,双击选择rows,next

rows的所有字段就出现了,将要打印的字段添兄冲加到右边,next

group by分组用不到,直接next

报表创建了

可以看到刚才选的字段都在Fields里了,然后就是逗族自己排版打印格式( JasperReport教程传送门 )

点击Preview预览

补充:遇到JSON DataAdapter报错了

仔细一看是右括号附近报错,其实就是最后的逗号问题,在js里允许这个写法,可能报表严格些,删掉最后的逗号就好了

1、ashx返回json数据,减少传租咐输数据量,html页面样式控制也比较灵活;

2、改写html页的jQuery代码;

3、把3个ashx文件简化为1个。

一、创建表的测试数据:

create table test(id int identity,title varchar(36))

declare @index int

set @index = 1

while(@index <8888)

begin

insert test(title) values (newid())

set @index = @index + 1

end

二、.html页

<html xmlns="http://www.w3.org/1999/xhtml" >

<head runat="server">

<title></title>

<script type="text/javascript" src="jquery-1.4.2.min.js"></script>

<script type="text/javascript">

$(function() {

Init()

})

function Init() {

$("#Content").html("")

$("#pageIndex").val(0)

$("#pageInfo").append("当前第1页")

$.getJSON("Handler.ashx", { type: 'first' }, function(data) {

$("#Content").append("<tr><th

style='width:130px'>id</th><th

style='width:150px'拦袜>title</th></tr>")

$.each(data, function(i) {

$("#Content").append("<tr><td>" +

data[i].id + "</td><td>" + data[i].title +

"</td></tr>")

})

})

}

function Pre() {

var currIndex = Number($("#pageIndex").val()) - 1

Go('pre', currIndex)

}

function Next() {

var currIndex = Number($("#pageIndex").val()) + 1

Go('next', currIndex)

}

function Go(type, index) {

$("#Content").html("")

$("#pageInfo").html("")

if (index == 0 || index == -1) { Init()return}

$.getJSON("Handler.ashx", { type: type, index: index }, function(data) {

$("#Content").append("<tr><th

style='width:130px'>id</th><th

style='width:150px'>title</th></tr>")

$.each(data, function(i) {

$("#Content").append("<tr><td>" +

data[i].id + "</td><td>" + data[i].title +

"</td></tr>")

})

$("#pageInfo").append("当前第 "简型激 + (index + 1) + " 页")

$("#pageIndex").val(index)

})

}

</script>

</head>

<body>

<form id="form1" runat="server">

<div style="width: 100%">

<table id="Content" >

</table>

</div>

<div id="PagePanel" style="margin-left:20px">

<label id="pageInfo"></label>

<a href="#" onclick="Pre()">上一页</a>

<a href="#" onclick="Next()">下一页</a>

</div>

<input type="hidden" value="0" id="pageIndex" />

</form>

</body>

</html>

三、.ashx页

public class Handler : IHttpHandler

{

public void ProcessRequest(HttpContext context)

{

context.Response.ContentType = "text/plain"

StringBuilder tb = new StringBuilder()

DataBase db = new DataBase()

int pageSize = 10

int pageIndex = 0

string type = context.Request.Params["type"]

switch (type)

{

case "first":

DataTable dt1 = db.GetDataSet("select top 10 * from test", null).Tables[0]

tb.Append(Common.DataTableToJSON(dt1, true))//DataTable转为JSON

break

case "next":

pageIndex = Convert.ToInt32(context.Request.Params["index"])

DataTable dt2 = db.GetDataSet("select top " +

pageSize.ToString() + " * from test where id>(select max(id) from

(select top " + (pageSize * pageIndex).ToString() + " id from test) t)",

null).Tables[0]

tb.Append(Common.DataTableToJSON(dt2, true))

break

case "pre":

pageIndex = Convert.ToInt32(context.Request.Params["index"])

DataTable dt3 = db.GetDataSet("select top " +

pageSize.ToString() + " * from test where id>(select max(id) from

(select top " + (pageSize * pageIndex).ToString() + " id from test) t)",

null).Tables[0]

tb.Append(JSONHelper.DataTableToJSON(dt))

break

}

context.Response.Write(tb.ToString())

}

public bool IsReusable

{

get

{

return false

}

}

}


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/tougao/12297192.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-22
下一篇2023-05-22

发表评论

登录后才能评论

评论列表(0条)

    保存