生成的CSV中没有换行符

no newlines in generated CSV

本文关键字:换行符 CSV      更新时间:2023-09-26

在我的页面中,我正在编写以下脚本来生成要下载的CSV。我的字符串'str'有一些新的行字符的"'n",但生成的csv都在一行中。我错过什么了吗?

            var fileContent = "data:text/csv;charset=utf-8," + str;
            var a = document.createElement('a');
            a.href = fileContent;
            a.download = filename;
            var e = document.createEvent('MouseEvents');
            e.initMouseEvent('click', true, false, window, 0, 0, 0, 0, 0, false, false, false, false, 0, null);
            a.dispatchEvent(e);

您需要将数据转换为base64

在大多数浏览器中,

就像

一样简单
var fileContent = "data:text/csv;charset=utf-8;base64," + btoa(str);

但是,如果您有一个Unicode字符串,这将失败。请考虑这样- source = http://mdn.beonex.com/en/DOM/window.btoa.html#Unicode_Strings

function utf8_to_b64( str ) {
    return window.btoa(unescape(encodeURIComponent(str)));
}
var fileContent = "data:text/csv;charset=utf-8;base64," + utf8_to_b64(str);