纯前端下载 csv 格式文件

该博客介绍了如何在前端实现CSV文件的下载功能。通过提供数据和表头,利用JavaScript创建并下载CSV文件。示例代码展示了从数据到CSV格式转换的过程,并通过创建HTML的a标签触发文件下载。此方法适用于前端数据导出场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

纯前端下载 csv 文件

table 数据

data() {
  return {
    header: [
      {
        _id: '01',
        label: '姓名',
        prop: 'name',
      },
      {
        _id: '02',
        label: '电话',
        prop: 'tel',
      },
      {
        _id: '03',
        label: '邮箱',
        prop: 'email',
      }
    ]
	tableData: [
	  {
	    name: 'jack',
	    tel: '0000-000000',
	    email: 'jack@xx.com'
	  },
	  {
	    name: 'mark',
	    tel: '0000-111111',
	    email: 'mark@xx.com'
	  }
	]
  }
}

下载 csv 文件函数

function downloadCsv(header, data, fileName = "导出结果.csv") {
  if (!header || !data|| !Array.isArray(header) || !Array.isArray(data) || !header.length || !data.length) {
    return;
  }
  // 下面 blob 位置指定了文件格式,在此处就不需要再指定了
  // var csvContent = '';
  var csvContent = 'data:text/csv;charset=utf-8,\ufeff';
  const _header = header.map(h => h.label).join(",");
  const keys = header.map(item => item.prop);
  csvContent += _header + '\r\n';
  data.forEach((item, index) => {
    let dataString = '';
    for (let i = 0; i < keys.length; i++) {
      dataString += item[keys[i]] + ','
    }
    csvContent += index < data.length ? dataString.replace(/,$/, '\r\n') : dataString.replace(/,$/, '');
  });
  // 使用编码转换包
  // import Encoding from 'encoding-japanese'
  // 安装:npm i encoding-japanese
  
  // const unicodeArray = Encoding.stringToCode(csvContent)
  // const sjisArray = Encoding.convert(unicodeArray, {
  //   to: 'SJIS',
  //   from: 'UNICODE'
  // })
  // const UintArray = new Uint8Array(sjisArray);
  // const blobUrl = new Blob([UintArray], {type: 'text/csv'});

  //  console.log(csvContent);
  const a = document.createElement('a');
  a.href = URL.createObjectURL(csvContent);
  a.download = fileName;
  a.click();
  window.URL.revokeObjectURL(csvContent);
}

结果

在这里插入图片描述

### 实现Vue前端文件转流下载 在现代Web应用中,允许用户通过浏览器下载由应用程序动态生成的文件是一个常见的需求。对于基于Vue.js的应用程序来说,在不依赖服务器的情况下实现这一功能可以通过创建Blob对象并将该对象转化为URL来完成。 #### 创建可下载链接的方法 为了使文件能够在客户端被处理成数据流并提供给用户下载,可以利用JavaScript中的`Blob`对象以及HTML5新增加的`<a>`标签属性`download`。这种方式使得整个过程可以在用户的浏览器端独立运行而无需额外的服务端支持[^1]。 下面是一段简单的示例代码展示了如何使用这种方法: ```javascript // 定义一个方法用于触发文件下载 methods: { downloadFile() { const content = '这里是你要保存的内容'; // 文件内容 // 将字符串转换为Blob对象 let blob = new Blob([content], { type: 'text/plain;charset=utf-8' }); // 如果是IE/Edge浏览器,则采用msSaveOrOpenBlob方式打开文件对话框 if (window.navigator && window.navigator.msSaveOrOpenBlob) { window.navigator.msSaveOrOpenBlob(blob, 'example.txt'); } else { // 对于其他主流浏览器,我们创建一个临时<a>元素来进行操作 var link = document.createElement('a'); // 设置href指向blob URL link.href = URL.createObjectURL(blob); // 设定下载后的文件名 link.download = 'example.txt'; // 添加到DOM树以便调用click事件模拟点击行为 document.body.appendChild(link); // 执行点击动作以启动下载 link.click(); // 清理工作:移除临时节点防止内存泄漏 setTimeout(() => { URL.revokeObjectURL(link.href); // 释放掉不再使用的object url资源 document.body.removeChild(link); }, 0); } } } ``` 这段代码片段定义了一个名为`downloadFile()`的方法,它接受一段文本作为输入参数,并将其封装在一个新的`Blob`实例里;接着根据不同的浏览器环境选择合适的方式让用户能够下载这个新创建出来的文件。此过程中并没有涉及到任何后台服务交互,完全是在前端完成了所有的逻辑处理[^2]。 #### 注意事项 当涉及更复杂的数据类型(比如JSON、CSV等),只需调整传入`Blob`构造函数的第一个参数即可满足不同格式的需求。另外需要注意的是,由于安全原因某些旧版浏览器可能不允许直接访问本地文件系统,因此上述方案主要适用于较新型号的支持HTML5特性的浏览器上。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值