转自:http://blog.csdn.net/educast/article/details/52775559

function JSONToExcelConvertor(JSONData, FileName, ShowLabel) {
//先转化json
var arrData = typeof JSONData != 'object' ? JSON.parse(JSONData) : JSONData;

var excel = '<table>';

//设置表头
var row = "<tr>";
for (var i = 0, l = ShowLabel.length; i < l; i++) {
row += "<td>" + ShowLabel[i] + '</td>';
}

//换行
excel += row + "</tr>";

//设置数据
for (var i = 0; i < arrData.length; i++) {
var row = "<tr>";

for (var index in arrData[i]) {
var value = arrData[i][index] === "." ? "" : arrData[i][index];
row += '<td>' + value + '</td>';
}

excel += row + "</tr>";
}

excel += "</table>";

var excelFile = "<html xmlns:o='urn:schemas-microsoft-com:office:office' xmlns:x='urn:schemas-microsoft-com:office:excel' xmlns='http://www.w3.org/TR/REC-html40'>";
excelFile += '<meta http-equiv="content-type" content="application/vnd.ms-excel; charset=UTF-8">';
excelFile += '<meta http-equiv="content-type" content="application/vnd.ms-excel';
excelFile += '; charset=UTF-8">';
excelFile += "<head>";
excelFile += "<!--[if gte mso 9]>";
excelFile += "<xml>";
excelFile += "<x:ExcelWorkbook>";
excelFile += "<x:ExcelWorksheets>";
excelFile += "<x:ExcelWorksheet>";
excelFile += "<x:Name>";
excelFile += "{worksheet}";
excelFile += "</x:Name>";
excelFile += "<x:WorksheetOptions>";
excelFile += "<x:DisplayGridlines/>";
excelFile += "</x:WorksheetOptions>";
excelFile += "</x:ExcelWorksheet>";
excelFile += "</x:ExcelWorksheets>";
excelFile += "</x:ExcelWorkbook>";
excelFile += "</xml>";
excelFile += "<![endif]-->";
excelFile += "</head>";
excelFile += "<body>";
excelFile += excel;
excelFile += "</body>";
excelFile += "</html>";

var uri = 'data:application/vnd.ms-excel;charset=utf-8,' + encodeURIComponent(excelFile);

var link = document.createElement("a");
link.href = uri;

link.style = "visibility:hidden";
link.download = FileName + ".xls";

document.body.appendChild(link);
link.click();
document.body.removeChild(link);
}

//var datas=[];
//var grid=getCmp("grid");
//var grid_data = grid.getStore();

//for(var i= 0 ;i< grid_data.data.length;i++){ //获取extjs grid的数据
//var row = grid_data.getAt(i).data;
//datas.push({"列头1":row["OrgName"],...});
//}

var datas=[{key:value}......];

JSONToExcelConvertor(datas,"汇总",["列头1","头2","头3"]);

3252DFE9-8E3E-4CC5-9414-F05F2E6447DA From: http://www.cnblogs.com/xuejianxiyang/p/7827894.html

最新文章

  1. Node.js配置And HelloWorld
  2. c++内存分布
  3. to my friends-Don&#39;t give up so fast
  4. Volley(三)—— ImageRequest &amp; Request简介
  5. mysql实用教程的数据构造
  6. Java浮点数精确计算
  7. MSSQLServer基础07(事务,存储过程,分页的存储过程,触发器)
  8. Python工程文件中的名词解释---Module与Package的区别
  9. 【移动开发】怎样自己定义ViewGroup
  10. C++ BigInteger 大整数类模板(转)
  11. spoj TSUM - Triple Sums fft+容斥
  12. Java系列 – 用Java8新特性进行Java开发太爽了(续)
  13. [扩展推荐] —— Laravel Log 增强
  14. Python Django系统
  15. 论文系统Step1:从日志记录中提取特定信息
  16. ON DUPLICATE KEY UPDATE单个增加更新及批量增加更新的sql
  17. PHP画图的基本步骤GD库
  18. View动画(补间动画)
  19. [Python] Python 虚拟机 - virtualenv
  20. C需要中的static

热门文章

  1. P1117 [NOI2016]优秀的拆分
  2. 使用Avd 调试慢的解决方案
  3. 洛谷 P3975 / loj 2102 [TJOI2015] 弦论 题解【后缀自动机】【拓扑排序】
  4. helloweblogic 官方qq群欢迎加入!
  5. ABP相关网站
  6. svn: Failed to run the WC DB work queue associated svn的bug解决
  7. numpy多维矩阵,取出第一行或者第一列,方法和df一样
  8. lucene原理
  9. django notes 一:开篇
  10. Java入门系列-25-NIO(实现非阻塞网络通信)