項目是Extjs的主要針對于Extjs GridPanel數據導出這塊先做一下說明。
我們可以通過Ext.getcmp()方法獲取到GridPanel對象并通過重寫的方法獲取Excel字符串具體方法可以百度到。這個應該也不是什么大問題。
//輸出報表
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);
}
以上是表單虛擬提交的方法。但是實驗了很多方法。發現數據post過去后無法生成Excel通過生成后下載方法也無法實現。(即在服務器端無法生成,但本機可以生成。)經過多次思路的轉折后來想到通過數據分析來調試。看看到底數據是否post到網頁
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文件
后來找到這個工具
具體步驟很簡單:
打開工具欄上的插件
雖然是英文的,但是不在話下。文檔都是看的英文的。
兩張近照
這邊就可以看到post過去以后的報錯信息。
這個是無刷新post無法看到的頁面。正因為這個而糾結了好久。今天終于知道哪錯了。
把錯誤信息復制到文本生成html文件。
原來是.net安全機制搞的鬼。
在web.config 的System.Web 后面加兩句話就搞定了。
<httpRuntime requestValidationMode="2.0" />
<pages validateRequest="false" />
好了 問題解決了 結博。