出于安全考虑,JS没法直接调用FileAPI写文件到磁盘,可是却能够经过下载来变相实现保存功能。
JS要实现下载功能,通常都是这么几个过程:生成下载的URL,动态建立一个A标签,并将其href指向生成的URL,而后触发A标签的单击事件,这样就会弹出下载对话框,从而实现了一个下载的功能。
这个属性很重要,它能够指定下载文件名,而且能够告诉浏览器目标连接是一个下载连接,不是一个普通连接,咱们看下面代码就能看出区别了:浏览器
<a href="data:text/txt;charset=utf-8,测试下载纯文本" rel="external nofollow" rel="external nofollow" rel="external nofollow" download="测试.txt" >下载1</a> <a href="data:text/txt;charset=utf-8,测试下载纯文本" rel="external nofollow" rel="external nofollow" rel="external nofollow" >下载2</a>
能够发现,下载1按钮可以实现下载,点击下载2连接时直接在浏览器打开文件内容了。安全
csv是一种逗号分隔的表格文件格式,能够很好的被Excel支持,因为其文件格式简单,因此常常用在简单的表格上面。最重要的是它是一种纯文本格式,能够很轻松地用JS来生成而不借助第三方库。编辑器
/** * 保存CSV文件 * @params csv csv文件内容 * @params saveName 保存的文件名 */ function saveCSV(csv, saveName){ var a = document.createElement('a'); a.href = 'data:text/csv;charset=utf-8,\ufeff' + encodeURIComponent(csv); a.download = saveName; a.click(); }
虽然咱们用的是UTF-8编码,下载后你会发现,用文本编辑器打开没问题,可是用Excel打开乱码:
缘由就是少了一个ufeffBOM头,因此在data里面添加一个\ufeff
解决了
文字换csv的最大问题就是如何处理换行,很简单,使用`\n`,`\r`后再用encodeURIComponent编码一下就能够了。
大部分浏览器可能都没啥问题,可是一些比较老的Chrome可能下载的时候指定的download就是不生效,此时能够用blob来解决:(测试此方法测试在微软Edge
浏览器和IE11下都没法下载)函数
/** * 保存CSV文件 * @params csv csv文件内容 * @params saveName 保存的文件名 */ function saveCSV(csv, saveName) { var blob = new Blob(['\ufeff' + csv], {type: 'text/csv,charset=UTF-8'}); openDownloadDialog(blob, saveName); }
此方法测试在微软Edge
浏览器能够实现下载,可是在IE11下仍是没法下载测试
const openDownloadDialog = (url, saveName) => { if (typeof url === 'object' && url instanceof Blob) { url = URL.createObjectURL(url); // 建立blob地址 } const aLink = document.createElement('a'); aLink.href = url; aLink.download = saveName; aLink.click(); };
下载text文件只须要修改一下文件类型就好了编码
function saveTXT(csv, saveName) { var blob = new Blob(['\ufeff' + csv], {type: 'text/txt,charset=UTF-8'}); openDownloadDialog(blob, saveName); }
保存文件的文件名后缀会影响打开方式,若是是.csv
的文件名,默认打开为excel,.txt
文件结尾的默认打开方式为text文件。因此这点须要注意url
我本身在项目中的封装excel
downLoadTools.js
code
const openDownloadDialog = (url, saveName) => { if (typeof url === 'object' && url instanceof Blob) { url = URL.createObjectURL(url); // 建立blob地址 } const aLink = document.createElement('a'); aLink.href = url; aLink.download = saveName; aLink.click(); }; export default { /** * 保存CSV文件 * @params csv csv文件内容 * @params saveName 保存的文件名 */ saveCSV: (csv, saveName) => { const blob = new Blob(['\ufeff' + csv], {type: 'text/csv,charset=UTF-8'}); openDownloadDialog(blob, `${saveName}.csv`); }, saveTXT: (csv, saveName) => { // const href = 'data:text/txt;charset=utf-8,\ufeff' + encodeURIComponent(csv); // ie浏览器不支持 const blob = new Blob(['\ufeff' + csv], {type: 'text/tet,charset=UTF-8'}); openDownloadDialog(blob, `${saveName}.txt`); } };
页面引用事件
import downLoadTools from '@/utils/downLoadTools'; // 引入 downLoadTools.saveTXT(csv, '文件名'); // csv是一个字符串, 最终会下载一个 文件名.txt 的文件