coffeescript实现nodejs前端csv文件下载

本文介绍了一种优雅的方法来实现在浏览器环境中创建CSV文件并下载的功能。通过使用JavaScript和Blob对象,可以轻松地将数据转换成CSV格式,并提供一个临时的下载链接供用户下载。此外,还解决了一个常见问题——即如何正确显示中文字符。

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

[There's a nicer way.]


代码段如下:

# alllw the browser to create a CSV file and download it.
# _arrays = [[..], [..],.., [..]]
# ps: "\uFEFF" to solve the problem of wrong display of chinese in excel

module.exports =
  csv: (_filename, _arrays)->
    # store data into a string
    _str = ''
    for _arr in _arrays
      _line = ''
      for _index in _arr
        _line += ',' if _line isnt ''
        _line += _index
      _str += _line + '\r\n'

    # create the click to download csv file
    _a = $('<a class="hide">点击下载</a>')
    _a.attr "download", "#{_filename}.csv"
    blob = new Blob ["\uFEFF" + _str], {'type':'application\/octet-stream'}
    _a.attr "href", window.URL.createObjectURL(blob)
    $("body").append _a
    _a[0].click()
    setTimeout ->
      _a.remove()
    , 1000

ps

(1)arrays为传入的参数,其中包含多个array,每个代表csv的一行数据,第一行为标题行

(2)整个过程分为两部分,一是将arrays中的数据传入到_str中,变成一个字符串;第二个部分是添加一个下载按钮并触发,下载相应文件,Blob(binary large object)为一种二进制大对象类型

(3)\uFEFF解决了excel打开下载文件中中文乱码的问题



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值