我有一些字符串需要是UTF-16文本文件。例如:
var s = "aosjdfkzlzkdoaslckjznx";
var file = "data:text/plain;base64," + btoa(s);
这将产生UTF-8编码文本文件。如何获取带有字符串s
的UTF-16文本文件?
答案 0 :(得分:6)
相关:Javascript to csv export encoding issue
这应该这样做:
document.getElementById('download').addEventListener('click', function(){
downloadUtf16('Hello, World', 'myFile.csv')
});
function downloadUtf16(str, filename) {
// ref: https://stackoverflow.com/q/6226189
var charCode, byteArray = [];
// BE BOM
byteArray.push(254, 255);
// LE BOM
// byteArray.push(255, 254);
for (var i = 0; i < str.length; ++i) {
charCode = str.charCodeAt(i);
// BE Bytes
byteArray.push((charCode & 0xFF00) >>> 8);
byteArray.push(charCode & 0xFF);
// LE Bytes
// byteArray.push(charCode & 0xff);
// byteArray.push(charCode / 256 >>> 0);
}
var blob = new Blob([new Uint8Array(byteArray)], {type:'text/plain;charset=UTF-16BE;'});
var blobUrl = URL.createObjectURL(blob);
// ref: https://stackoverflow.com/a/18197511
var link = document.createElement('a');
link.href = blobUrl;
link.download = filename;
if (document.createEvent) {
var event = document.createEvent('MouseEvents');
event.initEvent('click', true, true);
link.dispatchEvent(event);
} else {
link.click();
}
}
&#13;
<button id="download">Download</button>
&#13;
答案 1 :(得分:1)
您可以使用原生TextEncoder API的旧版polyfill将JavaScript字符串转换为ArrayBuffer。正如您在该文档中看到的那样,支持带有endianness 的UTF16 。以文本编码器兼容的方式提供UTF-16支持的库可能很快就会出现,如果还没有的话。让我们假设一个这样的库公开了一个名为ExtendedTextEncoder
的构造函数。
然后,您可以轻松创建Blob URL以允许用户下载文件,而无需进行低效的base-64转换。
这样的事情:
s = "aosjdfkzlzkdoaslckjznx"
var encoder = new ExtendedTextEncoder("utf-16be")
var blob = new Blob(encoder.encode(s), "text/plain")
var url = URL.createObjectURL(blob)
现在,您可以使用url
代替data:
网址。