web开发——写一个简单的表格导出操作
一、前台页面:
主要是一个按钮和一个表格,表格有显示数据,按钮负责将表格中的数据选择性地导出。除此外,可以附加一个小窗口和进度条,用于显示下载进度。
1. 按钮:<a href="javascript:;" class="easyui-linkbutton" iconCls="icon-redo" data-options="plain:true" id="btn-exp" onclick="fun_export()">导出详细信息</a>
2.表格:<div id="dataGrid" style="margin-bottom:5px;margin-top:1px">
<table id="dg" data-options="toolbar:'#tb'"></table>
</div>
3.进度条和小窗口
<div id="win" class="easyui-window" title="下载中" style="width: 500px; height: 80px" data-options="iconCls:'icon-save',modal:true">
<div id="p" class="easyui-progressbar" data-options="value:10" style="width:400px;margin-top:10px;margin-left:50px;"></div>
</div>
4.下载框:<iframe id="bgfileDownFrame" src="" style="display:none; visibility:hidden;"></iframe>
二、jS请求
<script>
function fun_export(){
$('#win').window('open');
setProgress();
//AJAX请求
$.ajax({
url:'${pageContext.request.contextPath}/media/getExl.action', //TODO
data:{},
type: 'post',
dataType:"json",
success: function(data){
// alert("导出!!!!!");
if(data.isSuccess == "true"){
$("#bgfileDownFrame").attr("src","${pageContext.request.contextPath}/media/downloadExl.action?docToken="+data.token);
value = 100;
setProgress();
$('#win').window('close');
}
else{
$('#win').window('close');
alert("生成统计表出错!");
}
},
});
}
//设置进度条的值
function setProgress(){
var value = $('#p').progressbar('getValue');
if (value < 100){
value += Math.floor(Math.random() * 20);
$('#p').progressbar('setValue', value);
setTimeout(arguments.callee, 200);
}
} </script>
三、action请求方法:
@Action(value="getExl")
public String getExl(){
Map<String,String> result = new HashMap<String,String>();
result.put("isSuccess", "false");
/* 数据来源*/
Map<String, Object> dataMap = new HashMap<String, Object>();//导出结果
List<Map<String, Object>> resultTable1 = mediaManageBPO.getMediaInfo();
dataMap.put("rows", resultTable1);
//路径
String webPath = this.request.getSession().getServletContext().getRealPath("");
MDoc mdoc = new MDoc();
try {
String tmpFileDir = webPath + File.separator +"docTemplate";
//检查临时文件夹是否存在
Util.checkDirExist(tmpFileDir);
//20161227105212956742620
String fileToken = Util.generateTmpFileName(tmpFileDir);
//fileToken 是生成的临时文件名
String docTemplatePath = webPath + File.separator +"docTemplate" + File.separator + fileToken;
//media.ftl是模板文件,先根据xls文件--另存为xml文件--eclipse下再重命名为ftl文件
String templateName = "media.ftl";
mdoc.createXls(dataMap, docTemplatePath,templateName);
result.put("isSuccess", "true");
result.put("token", fileToken);
this.request.getSession().setAttribute("DownloadFile","数据统计表"+UtilsLXJ.getDate());
} catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
outputJson(result);
return NONE;
}
//下载
@Action(value="downloadExl")
public String downloadExl(){
//数据统计表20161227105333.xls
String downloadName = (String)this.request.getSession().getAttribute("DownloadFile");
if(Util.trim(downloadName).isEmpty()){
downloadName = "数据统计.xls";
}else{
downloadName = downloadName + ".xls";
}
try {
OutputStream os = this.response.getOutputStream();
if (Util.isIE(this.request)) {
downloadName = URLEncoder.encode(downloadName, "utf-8");
} else {
downloadName = new String(downloadName.getBytes("utf-8"),
"iso-8859-1");
}
this.response.setContentType("application/x-download");
this.response.addHeader("Content-Disposition",
"attachment;filename=\"" + downloadName + "\"");
this.response.flushBuffer();
String webPath = this.request.getSession().getServletContext().getRealPath("");
//tmpFileDir临时文件的位置
String tmpFileDir = webPath + File.separator +"docTemplate";
//临时文件后面加上文件token
String bgFile = tmpFileDir + File.separator + docToken;//docToken是从getExl action那里传来的
FileInputStream fis = new FileInputStream(bgFile);
//输出
Util.copyStrem(fis, os);
fis.close();
os.close();
//删除临时文件
Util.delFile(bgFile);
} catch (IOException e) {
e.printStackTrace();
}
return NONE;
}
结果就是如下:
web开发——写一个简单的表格导出操作的更多相关文章
- 用Python写一个简单的Web框架
一.概述 二.从demo_app开始 三.WSGI中的application 四.区分URL 五.重构 1.正则匹配URL 2.DRY 3.抽象出框架 六.参考 一.概述 在Python中,WSGI( ...
- express 写一个简单的web app
之前写过一个简单的web app, 能够完成注册登录,展示列表,CURD 但是版本好像旧了,今天想写一个简单的API 供移动端调用 1.下载最新的node https://nodejs.org/zh- ...
- 动手写一个简单的Web框架(模板渲染)
动手写一个简单的Web框架(模板渲染) 在百度上搜索jinja2,显示的大部分内容都是jinja2的渲染语法,这个不是Web框架需要做的事,最终,居然在Werkzeug的官方文档里找到模板渲染的代码. ...
- 动手写一个简单的Web框架(Werkzeug路由问题)
动手写一个简单的Web框架(Werkzeug路由问题) 继承上一篇博客,实现了HelloWorld,但是这并不是一个Web框架,只是自己手写的一个程序,别人是无法通过自己定义路由和返回文本,来使用的, ...
- 动手写一个简单的Web框架(HelloWorld的实现)
动手写一个简单的Web框架(HelloWorld的实现) 关于python的wsgi问题可以看这篇博客 我就不具体阐述了,简单来说,wsgi标准需要我们提供一个可以被调用的python程序,可以实函数 ...
- 如何用PHP/MySQL为 iOS App 写一个简单的web服务器(译) PART1
原文:http://www.raywenderlich.com/2941/how-to-write-a-simple-phpmysql-web-service-for-an-ios-app 作为一个i ...
- 如何写一个简单的webserver(一):最简实现
本文主要讲述如何用C/C++在Linux环境下写一个简单的支持并发的web服务器,并不考虑服务器的健壮性.安全性.性能等一系列因素. 在本文中,该服务器仅支持GET请求. 项目地址:https://g ...
- 分享:计算机图形学期末作业!!利用WebGL的第三方库three.js写一个简单的网页版“我的世界小游戏”
这几天一直在忙着期末考试,所以一直没有更新我的博客,今天刚把我的期末作业完成了,心情澎湃,所以晚上不管怎么样,我也要写一篇博客纪念一下我上课都没有听,还是通过强大的度娘完成了我的作业的经历.(当然作业 ...
- 开发部署一个简单的Servlet
Servlet是一个执行在服务器端的Java Class文件,载入前必须先将Servlet程序代码编译成.class文件,然后将此class文件放在servlet Engline路径下.Servlet ...
随机推荐
- W3School-CSS 分类 (Classification) 实例
CSS 分类 (Classification) 实例 CSS 实例 CSS 背景实例 CSS 文本实例 CSS 字体(font)实例 CSS 边框(border)实例 CSS 外边距 (margin) ...
- android sqlite select,update,delete语法
String sql = "update recentsongtab set usetime=? , strdatetime=? where songid=?";//修改的SQL语 ...
- 【Windows编程】系列第三篇:文本字符输出
上一篇我们展示了如何使用Windows SDK创建基本控件,本篇来讨论如何输出文本字符. 在使用Win32编程时,我们常常要输出文本到窗口上,Windows所有的文本字符或者图形输出都是通过图形设备接 ...
- monkeyrunner之电脑安装驱动(五)
在Monkeyrunner做自动化测试时,可以使用模拟器,当然也可以选择用真机.不过,要想通过电脑来安装软件,操作手机,则必须先安装手机驱动,而且一般手机连接电脑之后,电脑会自动开始下载驱动.不过也经 ...
- CANopen学习——OSI模型复习
CanOpen协议实现了物理层和数据链路层,OSI模型是完整的7层. OSI模型网络七层包括物理层.数据链路层.网络层.传输层.会话层.表示层和应用层. 物理层:提供信息传输的物理连接通道,包括使用的 ...
- Catalan数应用整理
应用一: codevs 3112 二叉树计数 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 一个有n个结点的二叉树总共有 ...
- Vc6.0头文件的定义
Vc6.0头文件的定义 #ifndef __HEADER__ #define __HEADER__ int fun(int i); #endif
- nginx下目录浏览及其验证功能配置记录
工作中常常有写不能有网页下载东西的需求,在Apache下搭建完成后直接导入文件即可达到下载/显示文件的效果;而Nginx的目录列表功能默认是关闭的,如果需要打开Nginx的目录列表功能,需要手动配置, ...
- Linux 进程间通讯详解二
消息队列 --消息队列提供了本机上从一个进程向另外一个进程发送一块数据的方法 --每个数据块都被认为有一个类型,接收者进程接收的数据块可以有不同的类型值 --消息队列也有管道一样的不足,就是每个消息的 ...
- maven更改编译环境的java版本
<build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> ...