Javascript:创建UTF-16文本文件?

时间:2015-10-04 18:49:48

标签: javascript utf-16

我有一些字符串需要是UTF-16文本文件。例如:

var s = "aosjdfkzlzkdoaslckjznx";
var file = "data:text/plain;base64," + btoa(s);

这将产生UTF-8编码文本文件。如何获取带有字符串s的UTF-16文本文件?

2 个答案:

答案 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;
&#13;
&#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:网址。