前端通过js导出报表到excel(如果数据量很大的话,建议不要前端自己导出数据)

function tableToExcel(title,datalist){//title 列名 datalist 需要导出的json文件
		var jsonData=datalist;
      //列标题,逗号隔开,每一个逗号就是隔开一个单元格
      //var str = `1,2,3\n`;
			var str = title+"\n";
      //增加\t为了不让表格显示科学计数法或者其他格式
      for(var i = 0 ; i < jsonData.length ; i++ ){
        for(var item in jsonData[i]){
            str+=`${jsonData[i][item] + '\t'},`;     
        }
        str+='\n';
      }
      //encodeURIComponent解决中文乱码
      var uri = 'data:text/csv;charset=utf-8,\ufeff' + encodeURIComponent(str);
      //通过创建a标签实现
      var link = document.createElement("a");
      link.href = uri;
      //对下载的文件命名
      link.download =  "导出来的excel文件.csv";
      document.body.appendChild(link);
      link.click();
      document.body.removeChild(link);
    }

你可能感兴趣的:(JS)