是否可以使用Javascript / AJAX和服务器端响应(例如字符串)在客户端生成文件,然后打开此文件下载窗口?例如,一个简单的.txt
。
如果有可能,是否有任何解决方案可以生成.xlsx
个文件?
答案 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或你使用的任何东西中打开文件..