JS 在页面上直接将json数据导出到excel,支持chrome,edge,IE10+,IE9,IE8,Safari,Firefox

<html>

<head>

</head>

<body>



<script type="text/javascript">



function jsexport(){

    var jsonData = [{name:"张三", sex:"男", age:46},{name:"李四", sex:"男", age:20},{name:"王五", sex:"男", age:33},{name:"赵六", sex:"男", age:80}];

   

    var GridData = JSON.parse(JSON.stringify(jsonData))

    JSONToCSV(GridData, "UserReport.csv", true);

}



var blob;

var filename;

function c(){

window.navigator.msSaveOrOpenBlob(blob, filename);

}



function JSONToCSV(JSONData, ReportName, ShowLabel) {


    var arrData = typeof JSONData != 'object' ? JSON.parse(JSONData) : JSONData;

    var CSV = '';    

    if (ShowLabel) {

        var row = "";

        

        for (var index in arrData[0]) {

            row += index + ',';

        }

        row = row.slice(0, -1);

        CSV += row + '\r\n';

    }

    

    for (var i = 0; i < arrData.length; i++) {

        var row = "";

        for (var index in arrData[i]) {

            row += '"' + arrData[i][index] + '",';

        }

        row.slice(0, row.length - 1);

        //add a line break after each row

        CSV += row + '\r\n';

console.log(CSV);

    }





    if (CSV == '') {        

        alert("数据有错误");

        return;

    }   

    

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

    link.id="lnkDwnldLnk";

link.name="lnkDwnldLnk";

link.setAttribute("style", "display:none");





    var ifdo = document.createElement("iframe");    

    ifdo.id="ifdiframe";

ifdo.name="ifdiframe";

ifdo.setAttribute("style", "display:none");

    

    document.body.appendChild(link);

document.body.appendChild(ifdo);

   

var csv = CSV;


try

{

blob = new Blob([csv], { type: 'text/txt' }); 

}

catch (e)

{

blob = [csv];

}



var csvUrl = "";

filename = ReportName;

    if (window.navigator.userAgent.indexOf("Chrome") >= 1 || window.navigator.userAgent.indexOf("Safari") >= 1) { 

        csvUrl = window.webkitURL.createObjectURL(blob); 

link.setAttribute("download", filename);

link.setAttribute("href", csvUrl);

link.click();

    } 

    if (window.navigator.userAgent.indexOf("Firefox") >= 1) { 

        csvUrl = window.URL.createObjectURL(blob); 

link.setAttribute("download", filename);

link.setAttribute("href", csvUrl);

link.click();

    } 

    else { 

if(window.navigator.msSaveOrOpenBlob) { //IE>=10

link.addEventListener('click', function() {

window.navigator.msSaveOrOpenBlob(blob, filename);

});

link.click();





        } else { //支持IE9、IE8;  IE7及以下暂不支持,因为不支持JSON

            var ifd = document.getElementById('ifdiframe').contentDocument;

ifd.open('text/plain', 'replace');

ifd.write('\r\n\r\n' + csv);

ifd.close();

ifd.execCommand('SaveAs', null, filename);

        }

    }

  

    document.body.removeChild(link);

document.body.removeChild(ifdo);

}



</script>

<input type="Button" id="bygen" value="导出" onclick="jsexport()"/ >



<br>

<a id="mydownload" name="mydownload" href="#" >导出</a>



</html>

纯原生js代码,本人原创,未经许可可随意转载

JS 在页面上直接将json数据导出到excel,支持chrome,edge,IE10+,IE9,IE8,Safari,Firefox的更多相关文章

  1. Json数据导出生成Excel

    最近在做一个导入导出Excel的功能,导出其他类型的文件都比较熟悉,但是导入跟导出一个Excel还是稍微特殊点.根据这次的经验,写了个导出的小样例. 总体思路就是json数据的key,value跟Ex ...

  2. C#大量数据导出到Excel(转)

    工作过程中经常会用到将数据导出到Excel中,一般情况下需要导出的数据都是几百几千条或者上万条,这都没有什么问题,但有时候会遇到特殊的需求,客户要求把几十万条甚至上百万条的数据导出到Excel中,这就 ...

  3. 使用js在页面上新建文件夹

    使用js在页面上新建文件夹 <!DOCTYPE html> <html lang="en"> <head> <meta charset=& ...

  4. Progress.js – 为页面上的任意对象创建进度条效果

    Progress.js 是一个 JavaScript 和 CSS3 的库,它帮助开发人员为网页上的每个对象创建和管理进度条效果.你可以设计自己的模板,进度条或者干脆定制. 您可以使用 Progress ...

  5. js如何把字符串转换成json数据的方法

    js如何把字符串转换成json数据的方法 function strtojson(str){ var json = eval('(' + str + ')'); return json; } 方法二 f ...

  6. Nginx下HTML页面POST请求静态JSON数据返回405状态

    在浏览器访问HTML页面,发现一些静态JSON数据没有显示,F12查看,如下图所示: 可以看到请求方式为POST 将请求链接复制在浏览器地址栏访问,可以正常请求到数据 F12查看,可以看到请求方式为G ...

  7. 如何使用 js 检测页面上全局变量

    如何使用 js 检测页面上全局变量 js 检测页面全局变量脚本 <!DOCTYPE html> <html lang="zh-Hans"> <head ...

  8. json数据导出excel

    最近做的一个项目涉及到把数据导出到excel里面,网上找来找去,最终找到两种办法,废话不多说了 第一种: 拿到表格的id就可以抓取表格的数据,导出到excel,这种方式简单粗暴,引入这两个插件即可. ...

  9. asp.net 将repeater上数据导出到excel

    1,首先得到一个DataTable public DataTable GetTable(string sql) { SqlConnnection con=new SqlConnection(Confi ...

随机推荐

  1. Mybatis之动态构建SQL语句(转)

    https://www.cnblogs.com/zhangminghui/p/4903351.html

  2. ubuntu彻底删除apache2 再重装

    删除apache2不彻底,导致用 apt-get install apache2 重新装时总是不成功.下面是如何彻底删除apache2 1. 删除apache 代码: $ sudo apt-get - ...

  3. win7 C环境搭建

    1   http://jingyan.baidu.com/article/14bd256e4cb86ebb6d261287.html 2   http://jingyan.baidu.com/arti ...

  4. 第08章:MongoDB-CRUD操作--文档--删除

    ①语法 remove()  [2.6以后方法过时] deleteOne() [2.6以后官方推荐] deleteMany() [2.6以后官方推荐] db.collection.remove( < ...

  5. Linux top命令总结

    一:在bash里输入top后出现的数据当中目前自己容易理解的有 1.task:中的 num total表示总共有num个进程:num running是正在运行的进程数:num sleeping是正在休 ...

  6. Failed to place enough replicas

    如果DataNode的dfs.datanode.data.dir全配置成SSD类型,则执行"hdfs dfs -put /etc/hosts hdfs:///tmp/"时会报如下错 ...

  7. classmethod,staticmethod

    '''1 绑定方法: 在类内部定义的函数,默认就是给对象来用,而且是绑定给对象用的,称为对象的绑定方法 绑定对象的方法特殊之处: 应该由对象来调用,对象来调用,会自动将对象当作第一个参数传入 绑定到类 ...

  8. (转)转一份在 51testing 上的讨论——如何测试一个门户网站是否可以支持10万用户同时在线?

    转自:http://www.cnblogs.com/jackei/archive/2006/11/16/561846.html 这个帖子的内容比较典型,大家有兴趣可以也思考一下. 先是楼主提出问题: ...

  9. (转)如何最佳地使用memcached?

    转自:http://os.51cto.com/art/201205/335034_all.htm Memcached是由DangaInteractive开发的,高性能的,分布式的内存对象缓存系统,如何 ...

  10. Jack Straws(poj 1127) 两直线是否相交模板

    http://poj.org/problem?id=1127   Description In the game of Jack Straws, a number of plastic or wood ...