JSON到CSV / XLS不会在IE上保存文件

时间:2017-02-01 18:00:18

标签: javascript json export

我有以下服务:

angular.module('LBTable').service('exportTable', function () {
    function JSONToCSVConvertor(JSONData, ReportTitle, ShowLabel, fileName) {
        //If JSONData is not an object then JSON.parse will parse the JSON string in an Object
        var arrData = typeof JSONData != 'object' ? JSON.parse(JSONData) : JSONData;

        var CSV = '';
        //Set Report title in first row or line

        //CSV += ReportTitle + '\r\n\n';

        //This condition will generate the Label/Header
        if (ShowLabel) {
            var row = "";

            //This loop will extract the label from 1st index of on array
            for (var index in arrData[0]) {

                //Now convert each value to string and comma-seprated
                row += index + ',';
            }

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

            //append Label row with line break
            CSV += row + '\r\n';
        }

        //1st loop is to extract each row
        for (var i = 0; i < arrData.length; i++) {
            var row = "";

            //2nd loop will extract each column and convert it in string comma-seprated
            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';
        }

        if (CSV == '') {
            alert("Invalid data");
            return;
        }

        //Generate a file name
        fileName = (fileName != null ? fileName : 'Report');
        //this will remove the blank-spaces from the title and replace it with an underscore
        fileName += ReportTitle.replace(/ /g, "_");

        //Initialize file format you want csv or xls
        var uri = 'data:text/xls;charset=utf-8,' + escape(CSV);

        // Now the little tricky part.
        // you can use either>> window.open(uri);
        // but this will not work in some browsers
        // or you will not get the correct file extension

        //this trick will generate a temp <a /> tag
        var link = document.createElement("a");
        link.href = uri;

        //set the visibility hidden so it will not effect on your web-layout
        link.style = "visibility:hidden";
        link.download = fileName + ".xls";

        //this part will append the anchor tag and remove it after automatic click
        document.body.appendChild(link);
        link.click();
        document.body.removeChild(link);
    }

    return {
        exportCSV: JSONToCSVConvertor
    }
});

基本上它的作用是获取JSON对象并将其转换为csv文件,然后由用户下载

这在Chrome和Firefox中运行良好,但在IE(即使是最新版本)中没有下载任何文件,控制台也不会出现任何错误。

我的问题是为什么? :(

(简化小提琴)

Fiddle

1 个答案:

答案 0 :(得分:1)

原因是IE不支持标记中的下载属性。解决方法是使用blob

  1. 将JSON转换为CSV

  2. 检查当前浏览器是否可以使用以下代码

  3.  getInternetExplorerVersion() {
                var rv = -1;
                if (navigator.appName == 'Microsoft Internet Explorer') {
                    var ua = navigator.userAgent;
                    var re = new RegExp("MSIE ([0-9]{1,}[\.0-9]{0,})");
                    if (re.exec(ua) != null)
                        rv = parseFloat(RegExp.$1);
                }
                else if (navigator.appName == 'Netscape') {
                    var ua = navigator.userAgent;
                    var re = new RegExp("Trident/.*rv:([0-9]{1,}[\.0-9]{0,})");
                    if (re.exec(ua) != null)
                        rv = parseFloat(RegExp.$1);
                }
                return rv;
            }
    
    1. 如果浏览器是IE
    2. var blob = new Blob([CSV], { type: "text/csv;charset=utf-8;" });
      navigator.msSaveBlob(blob, fileName + ".csv")
      

      这适用于IE