ExtJs Excel導(dǎo)出并下載IIS服務(wù)器端遇到的問題
我們可以通過Ext.getcmp()方法獲取到GridPanel對象并通過重寫的方法獲取Excel字符串具體方法可以百度到。這個(gè)應(yīng)該也不是什么大問題。
//輸出報(bào)表
function ExportReport(title) {
var vExportContent = Ext.getCmp("gridPanel").getExcelXml(null, title);
if (Ext.isIE6 || Ext.isIE7 || Ext.isSafari || Ext.isSafari2 || Ext.isSafari3 || Ext.isIE8) {
// var frm = document.createElement('form');
// frm.id = 'frmExtjs';
// frm.className = 'x-hidden';
// document.body.appendChild(frm);
var f = document.createElement("form");
f.id = "frmExtjs";
document.body.appendChild(f);
var i = document.createElement("input");
i.type = "hidden";
i.id = "exportContent";
i.name = "exportContent";
f.appendChild(i);
i.value = vExportContent;
Ext.Ajax.request({
url: 'frmExcel.aspx',
method: 'POST',
form: Ext.get('frmExtjs'),
isUpload: true,
params: { FileName: title + '.xls' }
})
} else {
document.location = 'data:application/vnd.ms-excel;base64,' + Base64.encode(vExportContent);
}
以上是表單虛擬提交的方法。但是實(shí)驗(yàn)了很多方法。發(fā)現(xiàn)數(shù)據(jù)post過去后無法生成Excel通過生成后下載方法也無法實(shí)現(xiàn)。(即在服務(wù)器端無法生成,但本機(jī)可以生成。)經(jīng)過多次思路的轉(zhuǎn)折后來想到通過數(shù)據(jù)分析來調(diào)試。看看到底數(shù)據(jù)是否post到網(wǎng)頁
string tmpFileName = "export.xls";
string tmpContent = Request["ExportContent"];
if (Request["FileName"] != "")
{
tmpFileName = Request["FileName"];//獲取傳遞來的文件名?
tmpFileName = System.Web.HttpUtility.UrlEncode(Request.ContentEncoding.GetBytes(tmpFileName));//處理中文文件名的情況
}
Response.Clear();
Response.Buffer = true;
Response.ContentType = "application/vnd.ms-excel";
Response.AddHeader("Content-Disposition", "attachment;filename=\"" + tmpFileName + "\"");
Response.Charset = "";
System.IO.StringWriter tmpSW = new System.IO.StringWriter();
System.Web.UI.HtmlTextWriter tmpHTW = new System.Web.UI.HtmlTextWriter(tmpSW);
tmpHTW.WriteLine(tmpContent);
Response.Write(tmpSW.ToString());
Response.End();
以上是生成并下載的CS文件
后來找到這個(gè)工具
具體步驟很簡單:
打開工具欄上的插件
雖然是英文的,但是不在話下。文檔都是看的英文的。
兩張近照
這邊就可以看到post過去以后的報(bào)錯(cuò)信息。
這個(gè)是無刷新post無法看到的頁面。正因?yàn)檫@個(gè)而糾結(jié)了好久。今天終于知道哪錯(cuò)了。
把錯(cuò)誤信息復(fù)制到文本生成html文件。
原來是.net安全機(jī)制搞的鬼。
在web.config 的System.Web 后面加兩句話就搞定了。
<httpRuntime requestValidationMode="2.0" />
<pages validateRequest="false" />
好了 問題解決了 結(jié)博。
相關(guān)文章
extjs 學(xué)習(xí)筆記(三) 最基本的grid
extjs的一個(gè)亮點(diǎn)就是提供了豐富的UI,使得沒有藝術(shù)細(xì)胞的程序員也能做出絢麗的界面。把所有的UI集中到一起,有好處也有壞處,好處是有了統(tǒng)一的風(fēng)格和接口,壞處是js文件過于龐大,使用extjs的最小集合也超過了500k,所以在有些項(xiàng)目中并不適用。2009-10-10
關(guān)于extjs treepanel復(fù)選框選中父節(jié)點(diǎn)與子節(jié)點(diǎn)的問題
實(shí)現(xiàn)帶有復(fù)選框的樹,選中父節(jié)點(diǎn)時(shí),選中所有子節(jié)點(diǎn)。取消所有子節(jié)點(diǎn)時(shí),才能取消根節(jié)點(diǎn),感興趣的朋友可以了解下本文2013-04-04
Ext對基本類型的擴(kuò)展 ext,extjs,format
Ext對基本類型的擴(kuò)展 ext,extjs,format,學(xué)習(xí)extjs的朋友可以參考下。2010-12-12
ExtJS Store的數(shù)據(jù)訪問與更新問題
ExtJS Store的數(shù)據(jù)訪問與更新問題,需要的朋友可以參考下。2010-04-04





