http://hi.baidu.com/sunxiong0/blog/item/ca4a0012caaf4e5bf819b899.html
Ext导出excel很麻烦的,我们可以打开一个window.open()或window.location.href=''发送请求;把操作excel的工作交给后台的action处理就行了。
Ext的代码:
Ext.onReady(function() {
Ext.QuickTips.init();
Ext.BLANK_IMAGE_URL = '../ext/resources/images/default/s.gif';
Ext.form.Field.prototype.msgTarget = 'under';
var currentHeight = document.body.clientHeight;
var clientWidth = window.screen.width;
var Member = Ext.data.Record.create([{
name : 'id',
type : 'int'
}, {
name : 'devCode',
type : 'string'
}, {
name : 'devName',
type : 'string'
}, {
name : 'devModel',
type : 'string'
}, {
name : 'devDate',
type : 'string'
}, {
name : 'devTime',
type : 'string'
}, {
name : 'devReason',
type : 'string'
}, {
name : 'devState',
type : 'string'
}, {
name : 'processor',
type : 'string'
}, {
name : 'processTime',
type : 'string'
}, {
name : 'processResult',
type : 'string'
}, {
name : 'promoter',
type : 'string'
}, {
name : 'promoteTime',
type : 'string'
}, {
name : 'upgentDegree',
type : 'string'
}
, {
name : 'extStauts',
type : 'int'
}, {
name : 'reasonDescription',
type : 'string'
}, {
name : 'longTime',
type : 'string'
} ])
var itemStore = new Ext.data.GroupingStore({
groupField : 'devState',
groupOnSort : true,
sortInfo : {
field : "devState",
direction : "DESC"
},
proxy : new Ext.data.HttpProxy({
url : 'selectByToday.action'
}),
reader : new Ext.data.JsonReader({
root : 'members',
totalProperty : 'count',
fields : Member,
remoteSort : true,
applySort : {
field : "devName",
direction : "ASC"
}
}) });
// 创建工具栏
var toobar = new Ext.Toolbar([{
text : '导出Excel表格',
iconCls : 'go',
tooltip : '导出Excel表格',
handler : process }]);
// 创建选择模式对象
var cb = new Ext.grid.CheckboxSelectionModel({
singleSelect : true})
// 创建工具栏组件
var itemGrid = new Ext.grid.GridPanel({
// iconCls:'icon-grid',
id :'gridPanel',
applyTo : 'MalfunctionEquipmentGrid',
title : '当天已处理过的故障设备列表',
frame : true,// 渲染表格面板
tbar : toobar,// 顶端工具栏
store : itemStore,// 表格对应的数据集
stripeRows : true,// 显示斑马线
resizeable : true,// 设是否可以改变列宽置
collapsible : true, // 允许展开和收缩
height : Ext.get("MalfunctionEquipmentGrid").getHeight(),
bodyStyle : 'height:100%;width:100%;',
loadMask : true, // 使Gird加载数据时显示遮罩效果
autoScroll : true,
// enableColumnHide:false,//是否可以手动隐藏列
autoExpandColumn : 6,// 自动扩展最后一列
viewConfig:{
forceFit: true
// 自动充满表格
},
view : new Ext.grid.GroupingView({
forceFit : true,
groupTextTpl: '{text} (共{[values.rs.length]} 条 )',
groupByText : '使用当前字段进行分组',
showGroupsText : '表格分组',
showGroupName : true,
startCollapsed : true,
hideGroupedColumn : false
}),
sm : cb, // 设置表格的选择模式
columns : [ // 设置表的行号
cb, // 在表格中显示复选框
new Ext.grid.RowNumberer({
header : '行号',
width : 40
}), {
header : "编号",
dataIndex : 'id',
tooltip : '编号',
sortable : true,
hidden : true
}, {
header : "设备编号",
width : 50,
dataIndex : 'devCode',
tooltip : '设备编号',
sortable : true,
renderer :linker11
}, {
header : "设备名称",
width : 40,
dataIndex : 'devName',
tooltip : '设备名称',
sortable : true,
renderer : linker12
}, {
header : "设备型号",
width : 20,
dataIndex : 'devModel',
tooltip : '设备型号',
sortable : true,
renderer : linker12
}, {
header : "发生日期",
width : 35,
dataIndex : 'devDate',
tooltip : '故障发生日期',
sortable : true,
renderer : linker12
}, {
header : "发生时间",
width : 30,
dataIndex : 'devTime',
tooltip : '故障发生时间',
sortable : true,
renderer : linker12
}, {
header : "修复时间",
width : 30,
dataIndex : 'processTime',
tooltip : '故障修复时间',
sortable : true,
renderer : linker13
}, {
header : "修复耗时",
width : 30,
dataIndex : 'longTime',
tooltip : '故障修复耗时',
sortable : true
}, {
header : "处理人",
width : 20,
dataIndex : 'processor',
tooltip : '故障处理人',
sortable : true,
renderer : linker12
}, {
header : "处理结果",
width : 30,
dataIndex : 'processResult',
tooltip : '故障处理结果',
sortable : true,
renderer : linker12
}, {
header : "故障原因描述",
width : 40,
dataIndex : 'reasonDescription',
tooltip : '故障原因描述',
sortable : true,
renderer : linker12
}, {
header : "设备状态",
width : 30,
dataIndex : 'extStauts',
tooltip : '设备状态',
sortable : true,
hidden : true,
renderer : linker7
}, {
header : "处理发起人",
width : 30,
dataIndex : 'promoter',
tooltip : '故障处理发起人',
sortable : true,
hidden : true,
renderer : linker12
}
, {
header : "发起时间",
width : 30,
dataIndex : 'promoteTime',
tooltip : '故障发起时间',
sortable : true,
hidden : true,
renderer : linker12
}, {
header : "紧急程度",
width : 30,
dataIndex : 'upgentDegree',
tooltip : '紧急程度',
sortable : true,
hidden : true,
renderer : linker8
}, {
header : "处理状态",
width : 30,
dataIndex : 'devState',
sortable : true,
hidden : true
}
],
bbar : new Ext.PagingToolbar({
displayInfo : true,
afterPageText : ' 页 共 {0} 页',
beforePageText : '第 ',
firstText : '第一页 ',
prevText : '前一页',
nextText : '下一页',
lastText : '最后一页',
refreshText : '刷新',
pageSize : 30,
store : itemStore,
displayMsg : '显示第{0}条到{1}条记录,共{2}条记录',
emptyMsg : '没有记录'
}),
listeners : {
'cellclick' : function(grid, rowIndex, columnIndex, e) {
if (columnIndex == '3') {
// var smmx = new Ext.grid.CheckboxSelectionModel();
var win;
var rows = grid.getSelectionModel().getSelections();
if (rows.length > 1) {
Ext.MessageBox.alert('提示信息', '每次只能选择一个记录!');
return false;
} else {
id = rows[0].get('id');
var win3;
Ext.Ajax.request({
url : 'loadHistoryVendrecordMessageById.action?id=' + id,
waitMsg : "正在加载表单数据,请稍候...",
success : function(response, options) {
var r = Ext.decode(response.responseText);
if (r.success == true) {
var field;
if (!win) {
win3 = new Ext.Window({
layout : 'fit',
title : '查看详情',
width : 650,
height : 200,
closeAction : 'close',
plain : true,
modal : true,
html : r.data,
autoScroll : true,
buttonAlign : 'center',
buttons : [{
text : '确定',
handler : function() {
win3
.close();
}
}]
});
}
win3.show();
} else {
Ext.Msg.alert("提示信息", '查看故障设备信息失败');
}
}
});
}
}
}
}
})
itemStore.load({
params : {
start : 0,
limit : 30
}
});
window.onresize = function() {
itemGrid.setHeight(100);
itemGrid.setHeight(Ext.get('MalfunctionEquipmentGrid').getHeight());
};
function linker11(val) {
return '<u><font color="#11C2EE">'+val+'</font></u>'
}
function linker13(val) {
v = Ext.util.Format.substr(val,0,10);
v1 = Ext.util.Format.substr(val,11,16)
return "<span ext:qtip=" + v+"|"+v1 + ">" + v1 + "</span>";
}
function linker12(val) {
return "<span ext:qtip=" + val+ ">" + val + "</span>";
}
// 故障原因的显示转换
function linker(val) {
if (val == '1') {
return '通讯故障';
}
if (val == '2') {
return '模块故障';
}
if (val == '3') {
return '营业性故障';
}
if (val == '4') {
return '其它故障';
}
if (val == '5') {
return '手工录入';
}
return val;
}
function linker8(val){
if (val == '特急') {
return '<font color="#FF0000">特急</font>';
}
if (val == '紧急') {
return '<font color="#FF7F50">紧急</font>';
}
if (val == '一般') {
return '一般';
}
}
function linker1(val){
if (val == '1') {
return '<font color="#FF0000">关闭</font>';
}
if (val == '2') {
return '<font color="#FF7F50">维护</font>';
}
if (val == '3') {
return '未知';
}
if (val == '0') {
return '正常';
}
}
function linker2(val){
if (val == '1') {
return '<font color="#FF0000">通讯断</font>';
}
if (val == '2') {
return '<font color="#FF7F50">警告</font>';
}
if (val == '3') {
return '未知';
}
if (val == '0') {
return '正常';
}
if (val == '5') {
return '未录入';
}
}
function linker3(val){
if (val == '1') {
return '<font color="#FF0000">故障</font>';
}
if (val == '2') {
return '<font color="#FF7F50">警告</font>';
}
if (val == '3') {
return '未知';
}
if (val == '0') {
return '正常';
}
if (val == '5') {
return '未录入';
}
}
function linker4(val){
if (val == '1') {
return '<font color="#FF7F50">不足</font>';
}
if (val == '2') {
return '<font color="#FF0000">缺钞</font>';
}
if (val == '3') {
return '未知';
}
if (val == '0') {
return '充足';
}
if (val == '5') {
return '未录入';
}
}
function linker5(val){
if (val == '3') {
return '<font color="#FF0000">故障</font>';
}
if (val == '2') {
return '<font color="#FF7F50">缺纸</font>';
}
if (val == '1') {
return '<font color="#FF7F50">纸少</font>';
}
if (val == '0') {
return '正常';
}
if (val == '4') {
return '无';
}
if (val == '5') {
return '未录入';
}
}
function linker6(val){
if (val == '3') {
return '<font color="#FF0000">故障</font>';
}
if (val == '2') {
return '<font color="#FF7F50">缺纸</font>';
}
if (val == '1') {
return '<font color="#FF7F50">纸少</font>';
}
if (val == '0') {
return '正常';
}
if (val == '4') {
return '无';
}
if (val == '5') {
return '未录入';
}
}
function linker7(val){
if (val == '1') {
return '通讯故障';
}
if (val == '2') {
return '模块故障';
}
if (val == '3') {
return '营业性故障';
}
if (val == '0') {
return '其它故障';
}
if (val == '5') {
return '未录入';
}
}
//导出excel的函数
function process(){
Ext.MessageBox.confirm('确认提示', '你确定要导出Excel吗?',
function deldbconfig(btn) {
if (btn == 'yes') {
var msgTip = Ext.MessageBox.show({
title : '提示',
width : 350,
msg : '正在生成,请稍候......'
})
var _url = 'excelToHme.action?flag=2';
window.location.href(_url);
// window
// .open(_url, '_self',
// 'width=1,height=1,toolbar=no,menubar=no,location=no'); // 注意这里
// 用window.open()
// 否则不出现下载对话框
msgTip.hide();
}
})
}
});
后台:
/**
* 导出Excel——当天已处理的故障列表
*/
@SuppressWarnings("unchecked")
public String excelToHme() {
String flag = request.getParameter("flag");//用来区别是导出历史记录还是当天记录的
List<HistoryMalfunctionEquipment> listResult = null;
if(flag.equals("1")){//1表示历史记录
listResult = (List<HistoryMalfunctionEquipment>) session
.getAttribute("AllListResultHME");//在gird做查询的时候将查询的结果放在session里面,现在去取
}else if(flag.equals("2")){//2表示当天记录
listResult = (List<HistoryMalfunctionEquipment>) session
.getAttribute("listResultHME");
}
response.reset();
response.setContentType("application/vnd.ms-excel");
String titletop = "已处理的故障设备列表";
String[] title = { "设备编号", "设备名称", "设备型号", "故障发生日期", "故障发生时间",
"故障修复时间", "修复耗时", "故障处理人", "故障处理结果", "故障原因描述", "设备故障",
"故障处理发起人", "故障发起时间", "紧急程度", " 设备运行状态", "通讯状态", "模块状态", "钱箱状态",
"流水打印机状态", "收条打印机状态" };
List<CellView> cellviewList = new ArrayList<CellView>();
CellView cellview = null;
for (int i = 0; i < title.length; i++) {
cellview = new CellView();
cellview.setSize(4000); // 设置单元格的宽度
cellviewList.add(cellview);
}
try {
response.setHeader("Content-disposition", "attachment; filename="
+ new String("已处理的故障设备列表.xls".getBytes("GBK"),
"ISO8859_1"));
WritableWorkbook wwb;
wwb = Workbook.createWorkbook(response.getOutputStream());
WritableSheet sheet = wwb.createSheet(titletop, 0);
// 设置标题
Label label;
sheet.mergeCells(0, 0, 19, 0);// 合并单元格,
// 设置字体
jxl.write.WritableFont titalwfont = new jxl.write.WritableFont(
WritableFont.createFont("黑体"), 20);
titalwfont.setBoldStyle(WritableFont.BOLD);
WritableCellFormat titalfont = new WritableCellFormat(titalwfont);
titalfont.setAlignment(Alignment.CENTRE);
label = new Label(0, 0, titletop, titalfont);
sheet.addCell(label);
// begin
WritableCellFormat font = new WritableCellFormat();
font.setBorder(Border.ALL, BorderLineStyle.THIN, Colour.BLACK);
// end
// 备注
jxl.write.WritableFont topmemowfont = new jxl.write.WritableFont(
WritableFont.createFont("宋体"), 12);
WritableCellFormat topmemofontstart = new WritableCellFormat(
topmemowfont);
topmemofontstart.setAlignment(Alignment.CENTRE);
WritableCellFormat topmemofontend = new WritableCellFormat(
topmemowfont);
topmemofontend.setAlignment(Alignment.RIGHT);
// 设值表头
Label labels;
WritableCellFormat topwcf = new WritableCellFormat();
topwcf.setAlignment(Alignment.CENTRE);
topwcf.setBorder(Border.ALL, BorderLineStyle.THIN, Colour.BLACK);
for (int i = 0; i < title.length; i++) {
labels = new Label(i, 1, title[i], topwcf);
sheet.setColumnView(i, cellviewList.get(i));
sheet.addCell(labels);
}
// 以下是定义格式 Label为String型的,jxl.write.Number为数字
Label devCode;
Label devName;
Label devModel;
Label devDate;
Label devTime;
Label processor;
Label processTime;
Label longTime;
Label processResult;
Label promoter;
Label promoteTime;
Label upgentDegree;
Label extStatus;
Label devStatus;
Label commStatus;
Label moduStatus;
Label boxsStatus;
Label prjStatus;
Label prrStatus;
Label reasonDescription;
WritableCellFormat containtwcf = new WritableCellFormat();
containtwcf.setAlignment(Alignment.RIGHT);
containtwcf.setBorder(Border.ALL, BorderLineStyle.THIN,
Colour.BLACK);
for (int i = 2; i < listResult.size() + 2; i++) {
devCode = new Label(0, i, listResult.get(i - 2).getDevCode(),
font);
devName = new Label(1, i, listResult.get(i - 2).getDevName(),
font);
devModel = new Label(2, i, listResult.get(i - 2).getDevModel(),
font);
devDate = new Label(3, i, listResult.get(i - 2).getDevDate(),
font);
devTime = new Label(4, i, listResult.get(i - 2).getDevTime(),
font);
processTime = new Label(5, i, listResult.get(i - 2)
.getProcessTime(), font);
longTime = new Label(6, i, listResult.get(i - 2).getLongTime(),
font);
processor = new Label(7, i, listResult.get(i - 2)
.getProcessor(), font);
processResult = new Label(8, i, listResult.get(i - 2)
.getProcessResult(), font);
reasonDescription = new Label(9, i, listResult.get(i - 2)
.getReasonDescription(), font);
extStatus = new Label(10, i, parseState(listResult.get(i - 2)
.getExtStauts(), 0), font);
promoter = new Label(11, i,
listResult.get(i - 2).getPromoter(), font);
promoteTime = new Label(12, i, listResult.get(i - 2)
.getPromoteTime(), font);
upgentDegree = new Label(13, i, listResult.get(i - 2)
.getUpgentDegree(), font);
devStatus = new Label(14, i, parseState(listResult.get(i - 2)
.getDevStatus(), 1), font);
commStatus = new Label(15, i, parseState(listResult.get(i - 2)
.getCommStatus(), 2), font);
moduStatus = new Label(16, i, parseState(listResult.get(i - 2)
.getModuStatus(), 3), font);
boxsStatus = new Label(17, i, parseState(listResult.get(i - 2)
.getBoxsStatus(), 4), font);
prjStatus = new Label(18, i, parseState(listResult.get(i - 2)
.getPrjStatus(), 5), font);
prrStatus = new Label(19, i, parseState(listResult.get(i - 2)
.getPrrStatus(), 6), font);
sheet.addCell(devCode);
sheet.addCell(devName);
sheet.addCell(devModel);
sheet.addCell(devDate);
sheet.addCell(devTime);
sheet.addCell(processTime);
sheet.addCell(longTime);
sheet.addCell(processor);
sheet.addCell(processResult);
sheet.addCell(reasonDescription);
sheet.addCell(extStatus);
sheet.addCell(promoter);
sheet.addCell(promoteTime);
sheet.addCell(upgentDegree);
sheet.addCell(devStatus);
sheet.addCell(commStatus);
sheet.addCell(moduStatus);
sheet.addCell(boxsStatus);
sheet.addCell(prjStatus);
sheet.addCell(prrStatus);
}
wwb.write();
wwb.close();
response.getOutputStream().flush();
response.getOutputStream().close();
} catch (IOException e) {
log.error(e);
} catch (RowsExceededException e) {
log.error(e);
} catch (WriteException e) {
log.error(e);
}
return null;
}