是否可以使用JavaScript / AJAX在客户端创建文件?

时间:2016-05-17 20:12:48

标签: javascript ajax

是否可以使用Javascript / AJAX和服务器端响应(例如字符串)在客户端生成文件,然后打开此文件下载窗口?例如,一个简单的.txt

如果有可能,是否有任何解决方案可以生成.xlsx个文件?

1 个答案:

答案 0 :(得分:2)

这将创建一个CSV,您可以根据对象数组(window.EXPORTDATA)在Excel中打开:

        var csvContent = [];

        for(var i=0; i<window.EXPORTDATA.length; i++){
          var rowContent = [];
          var row = window.EXPORTDATA[i];
          if(csvContent.length === 0){
            for(var p in row)
              if(row.hasOwnProperty(p))
                rowContent.push('"'+ (""+p).replace('"','').replace(',','') +'"');
            csvContent.push("data:text/csv;charset=utf-8,"+rowContent.join(","));
            rowContent = [];
          }
          for(var p in row){
            if(row.hasOwnProperty(p))
              rowContent.push('"'+ (""+row[p]).replace('"','').replace(',','') +'"');
          }
          csvContent.push(rowContent.join(","));
        }

        var dat = csvContent.join("\n");
        var encodedUri = encodeURI(dat);
        window.open(encodedUri);

这是一个fiddle ..当你运行它时,它会要求你在Excel或你使用的任何东西中打开文件..