- 浏览: 127223 次
- 性别:
- 来自: 苏州
文章分类
- 全部博客 (80)
- Heritrix (1)
- eclispe (5)
- css (2)
- tomcat (2)
- mysql (8)
- Regex (3)
- JS (5)
- 其它 (7)
- 矢量图SVG (2)
- JDK_TOOL (2)
- FreeMarker (1)
- XML (2)
- excel (2)
- EXTJS (6)
- JAVA (7)
- openfire (1)
- Ant (1)
- freemarket (1)
- Spring (3)
- Hibernate (1)
- Swing (1)
- android (4)
- firefox插件 (1)
- cas原理 (2)
- Memcached (1)
- Graphics (1)
- jquery (1)
- JVM (2)
- NIO (1)
- socket (1)
- 浏览器 (1)
- ActiveMQ (1)
- hadoop (1)
- mysql主从数据库架构 (1)
- LVS (1)
- Transaction (1)
- struts2 (1)
- html5 (2)
- websocket (2)
- 开源网游 (2)
- linux (1)
- mybaits (1)
- redis (1)
- 编码 (1)
- Ngnix (1)
- 网络攻防 (1)
- mybatis (1)
- redison (1)
- bootstrap (1)
最新评论
-
coosummer:
推荐使用http://buttoncssgenerator.c ...
css,button,透明 -
jstl1point0:
我也遇到了,烦人
adb server is out of date. killing... 和 Adb connection Error:远程主机强迫关闭了一个现有的连接
Ext的ajax请求中如果配置了isUpload:true,则其
ajax就不是真正的ajax请求,而是通过创建一个隐藏的Iframe,并通过form的target指向这个iframe来提交数据,并
且发送的header里将content-type设为了multipart/form,在JSP中不能成功导出的原因就在这里。这样的提交方式
其参数通过request.getParameter是取不到的,当然你可以使用上传组件来获取,但这样代码就变得复杂。下面
来解决这个问题,既然这里的Ajax使用是一个模拟的form提交,那我们其实可以完全不用。我们直接用form提
交不是更省事吗?解决办法如下:创建一个隐藏form,其target设置为_blank,然后在其内部创建一个隐藏域存
放xml数据,然后通过POST方式提交这个form即可。
调用:
ajax就不是真正的ajax请求,而是通过创建一个隐藏的Iframe,并通过form的target指向这个iframe来提交数据,并
且发送的header里将content-type设为了multipart/form,在JSP中不能成功导出的原因就在这里。这样的提交方式
其参数通过request.getParameter是取不到的,当然你可以使用上传组件来获取,但这样代码就变得复杂。下面
来解决这个问题,既然这里的Ajax使用是一个模拟的form提交,那我们其实可以完全不用。我们直接用form提
交不是更省事吗?解决办法如下:创建一个隐藏form,其target设置为_blank,然后在其内部创建一个隐藏域存
放xml数据,然后通过POST方式提交这个form即可。
Ext.override(Ext.grid.GridPanel, { getExcelXml : function(includeHidden, config, sampleOvierr) { var worksheet = this.createWorksheet(includeHidden, config, sampleOvierr); var totalWidth = this.getColumnModel().getTotalWidth(includeHidden); return '<?xml version="1.0" encoding="utf-8"?>' + '<ss:Workbook xmlns:ss="urn:schemas-microsoft-com:office:spreadsheet" xmlns:x="urn:schemas-microsoft-com:office:excel" xmlns:o="urn:schemas-microsoft-com:office:office">' + '<o:DocumentProperties><o:Title>' + config.title + '</o:Title></o:DocumentProperties>' + '<ss:ExcelWorkbook>' + '<ss:WindowHeight>' + worksheet.height + '</ss:WindowHeight>' + '<ss:WindowWidth>' + worksheet.width + '</ss:WindowWidth>' + '<ss:ProtectStructure>False</ss:ProtectStructure>' + '<ss:ProtectWindows>False</ss:ProtectWindows>' + '</ss:ExcelWorkbook>' + '<ss:Styles>' + '<ss:Style ss:ID="Default">' + '<ss:Alignment ss:Vertical="Top" ss:WrapText="1" />' + '<ss:Font ss:FontName="arial" ss:Size="10" />' + '<ss:Borders>' + '<ss:Border ss:Color="#e4e4e4" ss:Weight="1" ss:LineStyle="Continuous" ss:Position="Top" />' + '<ss:Border ss:Color="#e4e4e4" ss:Weight="1" ss:LineStyle="Continuous" ss:Position="Bottom" />' + '<ss:Border ss:Color="#e4e4e4" ss:Weight="1" ss:LineStyle="Continuous" ss:Position="Left" />' + '<ss:Border ss:Color="#e4e4e4" ss:Weight="1" ss:LineStyle="Continuous" ss:Position="Right" />' + '</ss:Borders>' + '<ss:Interior />' + '<ss:NumberFormat />' + '<ss:Protection />' + '</ss:Style>' + '<ss:Style ss:ID="title">' + '<ss:Borders />' + '<ss:Font />' + '<ss:Alignment ss:WrapText="1" ss:Vertical="Center" ss:Horizontal="Center" />' + '<ss:NumberFormat ss:Format="@" />' + '</ss:Style>' + '<ss:Style ss:ID="headercell">' + '<ss:Font ss:Bold="1" ss:Size="10" />' + '<ss:Alignment ss:WrapText="1" ss:Horizontal="Center" />' + '<ss:Interior ss:Pattern="Solid" ss:Color="#A3C9F1" />' + '</ss:Style>' + '<ss:Style ss:ID="even">' + '<ss:Interior ss:Pattern="Solid" ss:Color="#CCFFFF" />' + '</ss:Style>' + '<ss:Style ss:Parent="even" ss:ID="evendate">' + '<ss:NumberFormat ss:Format="yyyy-mm-dd" />' + '</ss:Style>' + '<ss:Style ss:Parent="even" ss:ID="evenint">' + '<ss:NumberFormat ss:Format="0" />' + '</ss:Style>' + '<ss:Style ss:Parent="even" ss:ID="evenfloat">' + '<ss:NumberFormat ss:Format="0.00" />' + '</ss:Style>' + '<ss:Style ss:ID="odd">' + '<ss:Interior ss:Pattern="Solid" ss:Color="#CCCCFF" />' + '</ss:Style>' + '<ss:Style ss:Parent="odd" ss:ID="odddate">' + '<ss:NumberFormat ss:Format="yyyy-mm-dd" />' + '</ss:Style>' + '<ss:Style ss:Parent="odd" ss:ID="oddint">' + '<ss:NumberFormat ss:Format="0" />' + '</ss:Style>' + '<ss:Style ss:Parent="odd" ss:ID="oddfloat">' + '<ss:NumberFormat ss:Format="0.00" />' + '</ss:Style>' + '</ss:Styles>' + worksheet.xml + '</ss:Workbook>'; }, createWorksheet : function(includeHidden, config, sampleOvierr) { // Calculate cell data types and extra class names which affect formatting var cellType = []; var cellTypeClass = []; var cm = this.getColumnModel(); var totalWidthInPixels = 0; var colXml = ''; var headerXml = ''; var visibleColumnCountReduction = 0; var colCount = cm.getColumnCount(); for (var i = 0; i < colCount; i++) { if ((cm.getDataIndex(i) != '') && (includeHidden || !cm.isHidden(i))) { var w = cm.getColumnWidth(i) totalWidthInPixels += w; if (cm.getColumnHeader(i) === "") { cellType.push("None"); cellTypeClass.push(""); ++visibleColumnCountReduction; } else { colXml += '<ss:Column ss:AutoFitWidth="1" ss:Width="' + w + '" />'; headerXml += '<ss:Cell ss:StyleID="headercell">' + '<ss:Data ss:Type="String">' + cm.getColumnHeader(i) + '</ss:Data>' + '<ss:NamedCell ss:Name="Print_Titles" /></ss:Cell>'; var fld = this.store.recordType.prototype.fields.get(cm.getDataIndex(i)); if ("undefined"==typeof(fld)) { cellType.push("String"); cellTypeClass.push(""); } else { switch (fld.type) { case "int" : cellType.push("Number"); cellTypeClass.push("int"); break; case "float" : cellType.push("Number"); cellTypeClass.push("float"); break; case "bool" : case "boolean" : cellType.push("String"); cellTypeClass.push(""); break; case "date" : cellType.push("DateTime"); cellTypeClass.push("date"); break; default : cellType.push("String"); cellTypeClass.push(""); break; } } } } } var visibleColumnCount = cellType.length - visibleColumnCountReduction; var result = { height : 9000, width : Math.floor(totalWidthInPixels * 30) + 50 }; // Generate worksheet header details. var t = '<ss:Worksheet ss:Name="' + config.title + '">' + '<ss:Names>' + '<ss:NamedRange ss:Name="Print_Titles" ss:RefersTo="=\'' + config.title + '\'!R1:R2" />' + '</ss:Names>' + '<ss:Table x:FullRows="1" x:FullColumns="1"' + ' ss:ExpandedColumnCount="' + (visibleColumnCount + 2) + '" ss:ExpandedRowCount="' + (this.store.getCount() + 2) + '">' + colXml + // '<ss:Row ss:Height="38">' + // '<ss:Cell ss:StyleID="title" ss:MergeAcross="' + (visibleColumnCount - 1) + '">' + // '<ss:Data xmlns:html="http://www.w3.org/TR/REC-html40" ss:Type="String">' + // '<html:B>Generated by ExtJS</html:B></ss:Data><ss:NamedCell ss:Name="Print_Titles" />' + // '</ss:Cell>' + // '</ss:Row>' + '<ss:Row ss:AutoFitHeight="1">' + headerXml + '</ss:Row>'; // Generate the data rows from the data in the Store for (var i = 0, it = this.store.data.items, l = it.length; i < l; i++) { t += '<ss:Row>'; var cellClass = (i & 1) ? 'odd' : 'even'; r = it[i].data; var rTmp = null; if (i - 1 > -1) { rTmp = it[i - 1].data; } var k = 0; for (var j = 0; j < colCount; j++) { if ((cm.getDataIndex(j) != '') && (includeHidden || !cm.isHidden(j))) { var v = r[cm.getDataIndex(j)]; if (cellType[k] !== "None") { t += '<ss:Cell ss:StyleID="' + cellClass + cellTypeClass[k] + '"><ss:Data ss:Type="' + cellType[k] + '">'; if (cellType[k] == 'DateTime') { t += v.format('Y-m-d'); } else { // if(rTmp!=null){ // alert(sampleOvierr+"---"+v+"-----"+rTmp[cm.getDataIndex(j)]) // } if (sampleOvierr && j < 4 && (rTmp != null) && (v == rTmp[cm.getDataIndex(j)])) { t += "" } else { t += v; } } t += '</ss:Data></ss:Cell>'; } k++; } } t += '</ss:Row>'; } result.xml = t + '</ss:Table>' + '<x:WorksheetOptions>' + '<x:PageSetup>' + '<x:Layout x:CenterHorizontal="1" x:Orientation="Landscape" />' + '<x:Footer x:Data="Page &P of &N" x:Margin="0.5" />' + '<x:PageMargins x:Top="0.5" x:Right="0.5" x:Left="0.5" x:Bottom="0.8" />' + '</x:PageSetup>' + '<x:FitToPage />' + '<x:Print>' + '<x:PrintErrors>Blank</x:PrintErrors>' + '<x:FitWidth>1</x:FitWidth>' + '<x:FitHeight>32767</x:FitHeight>' + '<x:ValidPrinterInfo />' + '<x:VerticalResolution>600</x:VerticalResolution>' + '</x:Print>' + '<x:Selected />' + '<x:DoNotDisplayGridlines />' + '<x:ProtectObjects>False</x:ProtectObjects>' + '<x:ProtectScenarios>False</x:ProtectScenarios>' + '</x:WorksheetOptions>' + '</ss:Worksheet>'; return result; } }); var Base64 = (function() { var a = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/="; function b(e) { e = e.replace(/\r\n/g, "\n"); var d = ""; for (var g = 0; g < e.length; g++) { var f = e.charCodeAt(g); if (f < 128) { d += String.fromCharCode(f); } else { if ((f > 127) && (f < 2048)) { d += String.fromCharCode((f >> 6) | 192); d += String.fromCharCode((f & 63) | 128); } else { d += String.fromCharCode((f >> 12) | 224); d += String.fromCharCode(((f >> 6) & 63) | 128); d += String.fromCharCode((f & 63) | 128); } } } return d; } return { encode : function(e) { var c = ""; var m, k, h, l, j, g, f; var d = 0; e = b(e); while (d < e.length) { m = e.charCodeAt(d++); k = e.charCodeAt(d++); h = e.charCodeAt(d++); l = m >> 2; j = ((m & 3) << 4) | (k >> 4); g = ((k & 15) << 2) | (h >> 6); f = h & 63; if (isNaN(k)) { g = f = 64; } else { if (isNaN(h)) { f = 64; } } c = c + a.charAt(l) + a.charAt(j) + a.charAt(g) + a.charAt(f); } return c; } }; })(); Ext.ux.Exporter = function() { return { exportGrid : function(c, b, a) { a = a || {}; b = b || new Ext.ux.Exporter.ExcelFormatter(); var d = []; Ext.each(c.getColumnModel().config, function(e) { if (e.hidden != true && e.header != "管理" && e.id != "numberer" && e.id != "checker") { d.push(e); } }); Ext.applyIf(a, { title : c.title, columns : d }); return Base64.encode(b.format(c.store, a)); }, exportStore : function(a, c, b) { b = b || {}; c = c || new Ext.ux.Exporter.ExcelFormatter(); Ext.applyIf(b, { columns : b.store.fields.items }); return Base64.encode(c.format(a, b)); }, exportTree : function(a, d, c) { c = c || {}; d = d || new Ext.ux.Exporter.ExcelFormatter(); var b = a.store || c.store; Ext.applyIf(c, { title : a.title }); return Base64.encode(d.format(b, c)); } }; }(); Ext.ux.Exporter.exportXls = function(fileName, base64XMLObj,sampleOvierr) { var config = { store : null,//因为后续可能需要处理分页,因此此处一般不直接传递GridPanel的数据源 title : "标题"//需要显示标题 } var fd = Ext.get('frmDummy'); if (!fd) { fd = Ext.DomHelper.append(Ext.getBody(), { tag : 'form', method : 'post', id : 'frmDummy', action : "js/export/export.jsp", target : '_blank', name : 'frmDummy', cls : 'x-hidden', cn : [{ tag : 'input', name : 'fileName', id : 'fileName', type : 'hidden' }, { tag : 'input', name : 'base64Value', id : 'base64Value', type : 'hidden' }] }, true); } fd.child('#fileName').set({ value : fileName }); fd.child('#base64Value').set({ value : base64XMLObj.component.getExcelXml(false, config,sampleOvierr) }); fd.dom.submit(); // Ext.Ajax.request({ // url : 'js/export/export.jsp', // method : 'POST', // // callback : function(o, s, r) { // //alert(r.responseText); // }, // isupload : true, // params : { // fileName : fileName, // base64Value : base64Value // } // }); }; Ext.ux.Exporter.Button = Ext.extend(Ext.Button, { constructor : function(b) { b = b || { iconCls : "btn-print" }; Ext.applyIf(b, { exportFunction : "exportGrid", disabled : true, cls : "excel-cls", text : "导出", sampleOvierr:false }); if (b.store == undefined && b.component != undefined) { Ext.applyIf(b, { store : b.component.store }); } else { Ext.applyIf(b, { component : { store : b.store } }); } Ext.ux.Exporter.Button.superclass.constructor.call(this, b); if (this.store && Ext.isFunction(this.store.on)) { var a = function() { // this.getEl().child("a", true).href = "data:application/vnd.ms-excel;base64," + Ext.ux.Exporter[b.exportFunction](this.component, null, b); this.getEl().child("a", true).href = 'javascript:void(0);'//+Ext.ux.Exporter.exportXls(b.fileName+".xls", b.component.getExcelXml(false, config)) this.getEl().child("a", false).on('click', Ext.ux.Exporter.exportXls.createCallback(b.fileName+".xls", this,b.sampleOvierr), this); this.enable(); }; if (this.el) { a.call(this); } else { // this.on("render", a, this); } this.store.on("load", a, this); } }, template : new Ext.Template('<table border="0" cellpadding="0" cellspacing="0" class="x-btn-wrap"><tbody><tr>', '<td class="x-btn-left"><i> </i></td><td class="x-btn-center"><a class="x-btn-text" href="{1}" target="{2}">{0}</a></td><td class="x-btn-right"><i> </i></td>', "</tr></tbody></table>"), onRender : function(c, a) { var b, e = [this.text || " ", this.href, this.target || "_self"]; if (a) { b = this.template.insertBefore(a, e, true); } else { b = this.template.append(c, e, true); } var d = b.child("a:first"); this.btnEl = d; d.on("focus", this.onFocus, this); d.on("blur", this.onBlur, this); this.initButtonEl(b, d); Ext.ButtonToggleMgr.register(this); }, onClick : function(a) { if (a.button != 0) { return; } if (!this.disabled) { this.fireEvent("click", this, a); if (this.handler) { this.handler.call(this.scope || this, this, a); } } } }); Ext.reg("exportbutton", Ext.ux.Exporter.Button); Ext.ux.Exporter.Formatter = function(a) { a = a || {}; Ext.applyIf(a, {}); }; Ext.ux.Exporter.Formatter.prototype = { format : Ext.emptyFn }; Ext.ux.Exporter.ExcelFormatter = Ext.extend(Ext.ux.Exporter.Formatter, { format : function(b, c) { var a = new Ext.ux.Exporter.ExcelFormatter.Workbook(c); a.addWorksheet(b, c || {}); return a.render(); } }); Ext.ux.Exporter.ExcelFormatter.Workbook = Ext.extend(Object, { constructor : function(a) { a = a || {}; Ext.apply(this, a, { title : "Workbook", worksheets : [], compiledWorksheets : [], cellBorderColor : "#e4e4e4", styles : [], compiledStyles : [], hasDefaultStyle : true, hasStripeStyles : true, windowHeight : 9000, windowWidth : 50000, protectStructure : false, protectWindows : false }); if (this.hasDefaultStyle) { this.addDefaultStyle(); } if (this.hasStripeStyles) { this.addStripedStyles(); } this.addTitleStyle(); this.addHeaderStyle(); }, render : function() { this.compileStyles(); this.joinedCompiledStyles = this.compiledStyles.join(""); this.compileWorksheets(); this.joinedWorksheets = this.compiledWorksheets.join(""); return this.tpl.apply(this); }, addWorksheet : function(a, b) { var c = new Ext.ux.Exporter.ExcelFormatter.Worksheet(a, b); this.worksheets.push(c); return c; }, addStyle : function(a) { var b = new Ext.ux.Exporter.ExcelFormatter.Style(a || {}); this.styles.push(b); return b; }, compileStyles : function() { this.compiledStyles = []; Ext.each(this.styles, function(a) { this.compiledStyles.push(a.render()); }, this); return this.compiledStyles; }, compileWorksheets : function() { this.compiledWorksheets = []; Ext.each(this.worksheets, function(a) { this.compiledWorksheets.push(a.render()); }, this); return this.compiledWorksheets; }, tpl : new Ext.XTemplate('<?xml version="1.0" encoding="utf-8"?>', '<ss:Workbook xmlns:ss="urn:schemas-microsoft-com:office:spreadsheet" xmlns:x="urn:schemas-microsoft-com:office:excel" xmlns:o="urn:schemas-microsoft-com:office:office">', "<o:DocumentProperties>", "<o:Title>{title}</o:Title>", "</o:DocumentProperties>", "<ss:ExcelWorkbook>", "<ss:WindowHeight>{windowHeight}</ss:WindowHeight>", "<ss:WindowWidth>{windowWidth}</ss:WindowWidth>", "<ss:ProtectStructure>{protectStructure}</ss:ProtectStructure>", "<ss:ProtectWindows>{protectWindows}</ss:ProtectWindows>", "</ss:ExcelWorkbook>", "<ss:Styles>", "{joinedCompiledStyles}", "</ss:Styles>", "{joinedWorksheets}", "</ss:Workbook>"), addDefaultStyle : function() { var a = [{ name : "Color", value : this.cellBorderColor }, { name : "Weight", value : "1" }, { name : "LineStyle", value : "Continuous" }]; this.addStyle({ id : "Default", attributes : [{ name : "Alignment", properties : [{ name : "Vertical", value : "Top" }, { name : "WrapText", value : "1" }] }, { name : "Font", properties : [{ name : "FontName", value : "arial" }, { name : "Size", value : "10" }] }, { name : "Interior" }, { name : "NumberFormat" }, { name : "Protection" }, { name : "Borders", children : [{ name : "Border", properties : [{ name : "Position", value : "Top" }].concat(a) }, { name : "Border", properties : [{ name : "Position", value : "Bottom" }].concat(a) }, { name : "Border", properties : [{ name : "Position", value : "Left" }].concat(a) }, { name : "Border", properties : [{ name : "Position", value : "Right" }].concat(a) }] }] }); }, addTitleStyle : function() { this.addStyle({ id : "title", attributes : [{ name : "Borders" }, { name : "Font" }, { name : "NumberFormat", properties : [{ name : "Format", value : "@" }] }, { name : "Alignment", properties : [{ name : "WrapText", value : "1" }, { name : "Horizontal", value : "Center" }, { name : "Vertical", value : "Center" }] }] }); }, addHeaderStyle : function() { this.addStyle({ id : "headercell", attributes : [{ name : "Font", properties : [{ name : "Bold", value : "1" }, { name : "Size", value : "10" }] }, { name : "Interior", properties : [{ name : "Pattern", value : "Solid" }, { name : "Color", value : "#A3C9F1" }] }, { name : "Alignment", properties : [{ name : "WrapText", value : "1" }, { name : "Horizontal", value : "Center" }] }] }); }, addStripedStyles : function() { this.addStyle({ id : "even", attributes : [{ name : "Interior", properties : [{ name : "Pattern", value : "Solid" }, { name : "Color", value : "#CCFFFF" }] }] }); this.addStyle({ id : "odd", attributes : [{ name : "Interior", properties : [{ name : "Pattern", value : "Solid" }, { name : "Color", value : "#CCCCFF" }] }] }); Ext.each(["even", "odd"], function(a) { this.addChildNumberFormatStyle(a, a + "date", "[ENG][$-409]dd-mmm-yyyy;@"); this.addChildNumberFormatStyle(a, a + "int", "0"); this.addChildNumberFormatStyle(a, a + "float", "0.00"); }, this); }, addChildNumberFormatStyle : function(a, c, b) { this.addStyle({ id : c, parentStyle : "even", attributes : [{ name : "NumberFormat", properties : [{ name : "Format", value : b }] }] }); } }); Ext.ux.Exporter.ExcelFormatter.Worksheet = Ext.extend(Object, { constructor : function(a, b) { b = b || {}; this.store = a; Ext.applyIf(b, { hasTitle : true, hasHeadings : true, stripeRows : true, title : "sheet1",//修改sheet1的名字 columns : a.fields == undefined ? {} : a.fields.items }); Ext.apply(this, b); Ext.ux.Exporter.ExcelFormatter.Worksheet.superclass.constructor.apply(this, arguments); }, dateFormatString : "Y-m-d", worksheetTpl : new Ext.XTemplate( '<ss:Worksheet ss:Name="{title}">', "<ss:Names>", '<ss:NamedRange ss:Name="Print_Titles" ss:RefersTo="=\'{title}\'!R1:R2" />', "</ss:Names>", '<ss:Table x:FullRows="1" x:FullColumns="1" ss:ExpandedColumnCount="{colCount}" ss:ExpandedRowCount="{rowCount}">', "{columns}", // '<ss:Row ss:Height="38">',去掉首行的字样 // '<ss:Cell ss:StyleID="title" ss:MergeAcross="{colCount - 1}">', // '<ss:Data xmlns:html="http://www.w3.org/TR/REC-html40" ss:Type="String">', // '<html:B><html:U><html:Font html:Size="15">{title}', // '</html:Font></html:U></html:B></ss:Data><ss:NamedCell ss:Name="Print_Titles" />', // "</ss:Cell>", // "</ss:Row>", '<ss:Row ss:AutoFitHeight="1">', "{header}", "</ss:Row>", "{rows}", "</ss:Table>", "<x:WorksheetOptions>", "<x:PageSetup>", '<x:Layout x:CenterHorizontal="1" x:Orientation="Landscape" />', '<x:Footer x:Data="Page &P of &N" x:Margin="0.5" />', '<x:PageMargins x:Top="0.5" x:Right="0.5" x:Left="0.5" x:Bottom="0.8" />', "</x:PageSetup>", "<x:FitToPage />", "<x:Print>", "<x:PrintErrors>Blank</x:PrintErrors>", "<x:FitWidth>1</x:FitWidth>", "<x:FitHeight>32767</x:FitHeight>", "<x:ValidPrinterInfo />", "<x:VerticalResolution>600</x:VerticalResolution>", "</x:Print>", "<x:Selected />", "<x:DoNotDisplayGridlines />", "<x:ProtectObjects>False</x:ProtectObjects>", "<x:ProtectScenarios>False</x:ProtectScenarios>", "</x:WorksheetOptions>", "</ss:Worksheet>"), render : function(a) { return this.worksheetTpl.apply({ header : this.buildHeader(), columns : this.buildColumns().join(""), rows : this.buildRows().join(""), colCount : this.columns.length, rowCount : this.store.getCount() + 2, title : this.title }); }, buildColumns : function() { var a = []; Ext.each(this.columns, function(b) { a.push(this.buildColumn()); }, this); return a; }, buildColumn : function(a) { return String.format('<ss:Column ss:AutoFitWidth="1" ss:Width="{0}" />', a || 164); }, buildRows : function() { var a = []; this.store.each(function(b, c) { a.push(this.buildRow(b, c)); }, this); return a; }, buildHeader : function() { var a = []; Ext.each(this.columns, function(b) { var c; if (b.header != undefined) { c = b.header; } else { c = b.name.replace(/_/g, " "); c = c.charAt(0).toUpperCase() + c.substr(1).toLowerCase(); } a.push(String.format('<ss:Cell ss:StyleID="headercell"><ss:Data ss:Type="String">{0}</ss:Data><ss:NamedCell ss:Name="Print_Titles" /></ss:Cell>', c)); }, this); return a.join(""); }, buildRow : function(a, c) { var d, b = []; if (this.stripeRows === true) { d = c % 2 == 0 ? "even" : "odd"; } Ext.each(this.columns, function(f) { var e = f.name || f.dataIndex; if (Ext.isFunction(f.renderer)) { var h = f.renderer(a.get(e), null, a), g = "String"; } else { var h = a.get(e), g = this.typeMappings[f.type || a.fields.item(e).type]; } b.push(this.buildCell(h, g, d).render()); }, this); return String.format("<ss:Row>{0}</ss:Row>", b.join("")); }, buildCell : function(c, b, a) { if (b == "DateTime" && Ext.isFunction(c.format)) { c = c.format(this.dateFormatString); } return new Ext.ux.Exporter.ExcelFormatter.Cell({ value : c, type : b, style : a }); }, typeMappings : { "int" : "Number", "string" : "String", "float" : "Number", "date" : "DateTime" } }); Ext.ux.Exporter.ExcelFormatter.Cell = Ext.extend(Object, { constructor : function(a) { Ext.applyIf(a, { type : "String" }); Ext.apply(this, a); Ext.ux.Exporter.ExcelFormatter.Cell.superclass.constructor.apply(this, arguments); }, render : function() { return this.tpl.apply(this); }, tpl : new Ext.XTemplate('<ss:Cell ss:StyleID="{style}">', '<ss:Data ss:Type="{type}">{value}</ss:Data>', "</ss:Cell>") }); Ext.ux.Exporter.ExcelFormatter.Style = Ext.extend(Object, { constructor : function(a) { a = a || {}; Ext.apply(this, a, { parentStyle : "", attributes : [] }); Ext.ux.Exporter.ExcelFormatter.Style.superclass.constructor.apply(this, arguments); if (this.id == undefined) { throw new Error("An ID must be provided to Style"); } this.preparePropertyStrings(); }, preparePropertyStrings : function() { Ext.each(this.attributes, function(a, b) { this.attributes[b].propertiesString = this.buildPropertyString(a); this.attributes[b].children = a.children || []; Ext.each(a.children, function(d, c) { this.attributes[b].children[c].propertiesString = this.buildPropertyString(d); }, this); }, this); }, buildPropertyString : function(b) { var a = ""; Ext.each(b.properties || [], function(c) { a += String.format('ss:{0}="{1}" ', c.name, c.value); }, this); return a; }, render : function() { return this.tpl.apply(this); }, tpl : new Ext.XTemplate('<tpl if="parentStyle.length == 0">', '<ss:Style ss:ID="{id}">', "</tpl>", '<tpl if="parentStyle.length != 0">', '<ss:Style ss:ID="{id}" ss:Parent="{parentStyle}">', "</tpl>", '<tpl for="attributes">', '<tpl if="children.length == 0">', "<ss:{name} {propertiesString} />", "</tpl>", '<tpl if="children.length > 0">', "<ss:{name} {propertiesString}>", '<tpl for="children">', "<ss:{name} {propertiesString} />", "</tpl>", "</ss:{name}>", "</tpl>", "</tpl>", "</ss:Style>") });
调用:
function(grid,text,fileName,sampleOvierr){ var exportButton = new Ext.ux.Exporter.Button({ component: grid, iconCls: '', text : text==null?'导出':text, fileName : fileName==null?'导出':fileName, sampleOvierr: sampleOvierr==null?false:sampleOvierr });
<%@ page language="java" pageEncoding="UTF-8"%> <% response.setHeader("Content-Type","application/force-download"); response.setHeader("Content-Type","application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"); response.addHeader("Content-Disposition","attachment;filename="+request.getParameter("fileName") ); out.print(new String(request.getParameter("base64Value").getBytes("iso8859-1"),"UTF-8") ); %>
发表评论
-
extjs动态创建grid
2013-12-09 16:48 902/** * 将流程中grid的字 ... -
ExtJS让被遮盖的窗体显示在最前面以及解决Ext.MessageBox提示框被TabPanel覆盖的方法
2013-12-06 11:38 3508一、如何让ExtJS的弹出提示信息框Ext.Messa ... -
extjs RowEditor对 editgrid隐藏列赋值
2013-10-12 16:52 1690{ header : '使用 ... -
自己DIY java导出Excel
2013-08-05 10:56 953原创: 使用freeMarket结合注解生成excel(xm ... -
Ext设置emptyText
2013-08-02 09:02 1166var extAddress=Ext.getCmp(" ... -
JsonStore调用load方法之后可能出现超时
2013-08-01 16:21 851因为数据量较大,后台响应会比较慢,JsonStore调用loa ... -
xsl:template内容
2013-06-24 17:03 1041<xsl:template> 元素 <x ...
相关推荐
"extjs4导出excel"的功能就是实现了这个需求,让用户能够在ExtJS 4应用中方便地导出表格数据到Excel文件。 在ExtJS 4中实现数据导出至Excel通常涉及以下几个关键步骤: 1. **数据收集**:首先,你需要收集要导出的...
在EXTJS4中,实现导出数据到Excel的功能是一项常见的需求,这可以帮助用户方便地处理和存储大量数据。本示例将详细介绍EXTJS4如何实现Excel导出,并提供相关的代码示例。 EXTJS4的核心是其组件模型,包括表格(Grid...
总之,ExtJS6的导出Excel功能结合了分组、分组合计行和二重表头,使得数据网格的数据导出更加灵活且信息丰富。通过自定义和扩展,开发者可以创建满足特定业务场景的导出解决方案。而这个过程往往需要对ExtJS的API有...
本文将深入讲解EXTJS Grid如何实现数据导出到Excel文件的功能。 首先,我们要明白EXTJS Grid的数据导出到Excel的过程通常涉及到以下几个步骤: 1. **获取Grid数据**:在EXTJS中,Grid的数据存储在Store对象中。要...
EXTJS是一个基于JavaScript的...以上就是EXTJS Grid导出Excel文件的相关知识点,理解并掌握这些内容可以帮助你实现从EXTJS应用中导出数据到Excel的功能。在实际开发中,还需要考虑性能优化、错误处理以及兼容性问题。
在EXTJS Grid中导出数据到Excel是一种常见的需求,它允许用户方便地处理和分析大量数据。EXTJS是一个强大的JavaScript库,专门用于构建富客户端Web应用程序,而Grid组件是其核心部分,用于展示和管理表格数据。在...
你需要指定导出的类型(如'csv'或'excel'),以及可能的样式和格式选项。 ```javascript features: [{ ftype: 'exporter', type: 'excel', // 或者 'csv' header: true, // 是否包含列头 style: { font: '宋体...
当用户在EXTJS Grid中选择要导出的列后,前端会发送请求到ASP.NET服务器,服务器处理请求,筛选出指定列的数据,然后使用Excel库(如EPPlus、NPOI等)生成Excel文件。 “数据表格里的列可自选的,可隐藏不想导出的...
Struts1.2 + ExtJS + 导出Excel项目是一个基于Web的应用开发框架组合,用于构建企业级的Java应用程序。这个项目的重点在于整合Struts1.2(一个经典的MVC框架)与ExtJS(一个富客户端JavaScript库)来提供用户友好的...
本文主要探讨的是使用Extjs4.2框架实现纯前台导出Excel功能,并针对多次导出失败的问题进行了修复。 Extjs是一个强大的JavaScript库,专用于构建富客户端应用。版本4.2是其稳定且广泛使用的版本,提供了丰富的组件...
在本篇文章中,我们将深入探讨如何在ExtJS4中实现前台Grid的数据导出到Excel功能。 首先,我们需要了解`Ext.grid.Panel`,这是ExtJS中的核心组件之一,用于创建数据网格。它能够动态加载数据,提供排序、过滤、分页...
使用`download`属性指定文件名,如"export.csv"。 5. **模拟点击**:触发`<a>`标签的点击事件,这样浏览器就会开始下载CSV数据,用户可以选择保存为Excel文件。 6. **浏览器兼容性**:需要注意的是,这种基于`data...
Extjs4 grid 导出为Excel 下载后放在网站(不放在网站中导出按钮不能会点击无响应,因为这里调用了swf文件)里可直接运行index.html测试 <link href='...
当我们需要将Ext Grid中的数据导出为Excel格式时,这通常涉及到数据的处理和转换,以便用户能够方便地在离线环境中分析或共享。这篇博客"Ext Grid 导出Excel"可能详细介绍了如何实现这一功能。 首先,让我们理解Ext...
"ExtJS导出Excel"的功能则是允许用户将`grid`中的数据方便地导出为Excel格式,这样可以方便数据的保存、分析和共享。 在实现页面级的ExtJS `grid`数据导出到Excel时,通常会涉及到以下几个关键知识点: 1. **ExtJS...
看了网上很多报表demo后, 感觉狠不够详细,有鉴于此,本人特开一帖进行了细解,祥见本人博客或http://my.oschina.net/yexingqianli/blog/170434 ,望批评指正,多多交流为善
在EXTJS 中,导入和导出Excel 文件是常见的需求,特别是在处理大量数据时,Excel 的格式化和编辑能力非常有用。 ### 导出到Excel EXTJS 提供了多种方式来实现数据到Excel 的导出。一种常见的方式是通过服务器端...
### ExtJS实现Excel导出:深入解析与实践 在当今高度数字化的工作环境中,数据的管理和呈现方式至关重要。其中,Excel作为数据处理和分析的重要工具,其导出功能在各种应用场景中显得尤为关键。ExtJS,作为一种强大...
5. **数据导入导出**:用户可以上传本地的Excel文件进行在线编辑,也可以将编辑后的数据导出为Excel格式,方便数据交换。 6. **权限控制**:通过集成的身份验证和权限管理,可以限制不同用户对数据的访问和操作权限...
ExtJS的GridPanel导出excel文件,方便快捷易懂!