[ExtJS5学习笔记]第三十三节 sencha extjs 5 grid表格导出excel

使用extjs肯定少不了使用表格控件,用到表格,领导们(一般)还是惯于使用excel看数据,所以用到extjs表格的技术猿们肯定也会有导出表格excel这一个需求,本文主要针对如何在用extjs将grid表格导出到excel,使用的是前端导出,不涉及后端。


源代码打包下载

本次使用的是github上的一个开源项目Exporter
下载地址:https://github.com/iwiznia/Ext.ux.Exporter
下载之后,可以看到文件目录是这样的(已经是4年前维护的项目了):

项目概述

将源代码嵌入到应用中

要实现功能的话,这里面的所有文件都要加到项目中的。
然后,需要在使用导出的页面上加入这个js文件的引入:

<script type="text/javascript" src="<%=context %>/pages/yourpathtojsppage/export-all.js"> </script>
在extjs的onready之前引入如下所需:

          Ext.Loader.setConfig({ enabled: true });
          Ext.Loader.setPath('Ext.ux.exporter', 'exporter'); 
          Ext.require([
            'Ext.ux.exporter.Exporter'
          ]);

grid定义的时候加上导出excel的入口:

var grid = Ext.create('Ext.grid.Panel', {
frame: true,
title: 'test',
columnLines: true, // 加上表格线  
height: 800,
features: [{
    ftype: 'summary'
}],     
columns: [{yourclolunms}],
  store: ytkbbStore, 
          dockedItems: [{
  xtype: 'toolbar', 
  dock: 'top',
  items: [{xtype: 'exporterbutton',store: yourStore}]
         }],
renderTo: Ext.getBody()

});

这样,就实现了将导出excel的功能嵌入到了应用程序中。

查看导出按钮以及导出效果

查看grid表格,发现已增加按钮,如图:
这里写图片描述

时间费用kg
2014-032271882.74
2014-041461200.12
2014-051871561.27
2014-06111930.18
2014-0750 433.5
2014-081501267.5
2014-091641343.75
2014-101341070.66

导出之后的excel截图如下:
这里写图片描述

可以看到正确进行了数据导出.

扩展支持sum统计和groupsum分组

技巧:对worksheet.js 进行修改可以调整表格设置,表格内容的出来都是在这里。
//增加合计行
if (this.hasSum){
var style;
Ext.each(this.columns, function(col,index,self) {
style = ‘odd’;
if (col.summaryType==”sum”){
var v = this.store.sum(col.dataIndex);
cells.push(this.buildCell(‘合计: ’ + v, ‘String’, style).render())
}else{
cells.push(this.buildCell(”, ‘String’, style).render())
}
}, this);
rows.push(Ext.String.format(“{0}”, cells.join(“”)));
};

以上是对最后一个统计行的处理。
//分组合计行
buildGroupSumRow: function(me, groupkey, store) {
var style,cells = [];
if (me.stripeRows === true) style = ‘odd’;
type = ‘String’;
var insertRow = function(me){
Ext.each(me.columns, function (col, dataIndex) {
if (!col.groupSumField){
cells.push(me.buildCell(”, type, style).render());
}else{
var abc = store.getGroups().getByKey( groupkey );//sumByGroup(store.groupField);
var sumabc = abc.sum(col.dataIndex);
cells.push(me.buildCell(‘合计: ‘+sumabc, type, style).render());
}
});
return Ext.String.format(“{0}”, cells.join(“”));
};
return insertRow(this);
}
以上是处理分组的,可以实现sum方法合计也可以取平均值等。OK到现在就可以正确的导出表格数据到excel了。

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 9
    评论
以下是一个使用ExtJS 4.2.1的完整例子,可以将Grid表格导出Excel文件: ``` Ext.require([ 'Ext.grid.*', 'Ext.data.*', 'Ext.util.*', 'Ext.toolbar.Paging', 'Ext.ux.exporter.Exporter' ]); Ext.onReady(function() { // 模拟数据 var data = []; for (var i = 0; i < 20; i++) { data.push({ name: 'User ' + i, email: 'user' + i + '@example.com', phone: '555-' + Ext.Number.randomInt(1000, 9999) }); } // 创建数据模型 Ext.define('User', { extend: 'Ext.data.Model', fields: ['name', 'email', 'phone'] }); // 创建数据源 var store = Ext.create('Ext.data.Store', { model: 'User', data: data, proxy: { type: 'memory', reader: { type: 'json', root: 'data' } } }); // 创建Grid表格 var grid = Ext.create('Ext.grid.Panel', { store: store, columns: [{ text: 'Name', dataIndex: 'name' }, { text: 'Email', dataIndex: 'email', flex: 1 }, { text: 'Phone', dataIndex: 'phone' }], width: 400, height: 200, dockedItems: [{ xtype: 'toolbar', dock: 'top', items: [{ xtype: 'button', text: 'Export to Excel', handler: function() { // 导出Excel Ext.ux.exporter.Exporter.exportGrid(grid, 'Excel', { title: 'User List' }); } }] }, { xtype: 'pagingtoolbar', store: store, dock: 'bottom', displayInfo: true }] }); // 渲染Grid表格 Ext.create('Ext.container.Viewport', { layout: 'fit', items: [grid] }); }); ``` 在上面的代码中,我们首先定义了一个模拟数据数组,然后创建了一个数据模型和一个数据源。接下来,我们创建了一个Grid表格,将数据源绑定到该表格中,并添加了一个工具栏和一个分页工具栏。在工具栏中,我们添加了一个按钮,当用户单击该按钮时,将调用Ext.ux.exporter.Exporter.exportGrid函数将Grid表格导出Excel文件。 需要注意的是,我们使用了Ext.ux.exporter.Exporter类来执导出操作。该类是ExtJS的一个扩展,需要在应用程序中明确声明。在本例中,我们使用了Ext.require函数来加载必需的类和扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值