[转]纯js导出json到excel(支持chrome)
转自: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
最新文章
- Node.js配置And HelloWorld
- c++内存分布
- to my friends-Don&#39;t give up so fast
- Volley(三)—— ImageRequest &; Request简介
- mysql实用教程的数据构造
- Java浮点数精确计算
- MSSQLServer基础07(事务,存储过程,分页的存储过程,触发器)
- Python工程文件中的名词解释---Module与Package的区别
- 【移动开发】怎样自己定义ViewGroup
- C++ BigInteger 大整数类模板(转)
- spoj TSUM - Triple Sums fft+容斥
- Java系列 – 用Java8新特性进行Java开发太爽了(续)
- [扩展推荐] —— Laravel Log 增强
- Python Django系统
- 论文系统Step1:从日志记录中提取特定信息
- ON DUPLICATE KEY UPDATE单个增加更新及批量增加更新的sql
- PHP画图的基本步骤GD库
- View动画(补间动画)
- [Python] Python 虚拟机 - virtualenv
- C需要中的static
热门文章
- P1117 [NOI2016]优秀的拆分
- 使用Avd 调试慢的解决方案
- 洛谷 P3975 / loj 2102 [TJOI2015] 弦论 题解【后缀自动机】【拓扑排序】
- helloweblogic 官方qq群欢迎加入!
- ABP相关网站
- svn: Failed to run the WC DB work queue associated svn的bug解决
- numpy多维矩阵,取出第一行或者第一列,方法和df一样
- lucene原理
- django notes 一:开篇
- Java入门系列-25-NIO(实现非阻塞网络通信)