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

标签 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 )

Fiddle

最佳答案

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

  1. 将 JSON 转换为 CSV

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

 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;
        }
  • 如果浏览器是IE
  • var blob = new Blob([CSV], { type: "text/csv;charset=utf-8;" });
    navigator.msSaveBlob(blob, fileName + ".csv")
    

    这适用于 IE

    关于javascript - JSON 到 CSV/XLS 不会在 IE 上保存文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41986563/

    相关文章:

    mysql - 当结果 > 199 时 $.getJSON 返回未定义

    json - JMeter - 将所有请求的完整 JSON 响应保存到 CSV 文件以准备测试数据

    javascript - 如何在react中使用多个 `export default `

    javascript - 无法在 jQuery 中突出显示具有特殊字符的单词

    javascript - 在一些 jquery wordpress 中 Hook 时遇到问题

    java - GSON 序列化多态对象,类型存储在不同的对象中

    mysql - 无法在MySql工作台中导出数据

    pdf - MATLAB:正确调整图形大小

    javascript - 如何使用 hwcrypto.js 检测使用 usb-token 的人

    javascript - 使用 JSON 显示两个图表