JS生成txt文件并下载

有时候需要下载一些信息,而后端却又不给我提供接口。我们就可以采用下面的方式,将一些信息保存下载到一个txt文件中使用。下面我们提供两种下载txt的方式。

一、采用a标签的download属性实现下载

通过a标签指定文本格式和编码直接下载

/*

* fileName: txt文件名称

* content:文件内容(string)

*/

function downloadTxt(fileName, content) {

    let a = document.createElement('a');

    a.href = 'data:text/plain;charset=utf-8,' + content

    a.download = fileName

    document.body.appendChild(a);

    a.click();

    document.body.removeChild(a);

}

二、通过文件流的形式下载

通过FileReader转化为base64字符串下载

function downloadTxt(fileName, content) {

   let blob = new Blob([content], {

       type: "text/plain;charset=utf-8"

    });

   let reader = new FileReader();

   reader.readAsDataURL(blob);

   reader.onload = function(e) {

  let a = document.createElement('a');

  a.download = fileName;

  a.href = e.target.result;

  document.body.appendChild(a);

  a.click();

  document.body.removeChild(a);

  }

}

function downloadTxt(fileName, content) {

   let blob = new Blob([content], {

       type: "text/plain;charset=utf-8"

    });

   let reader = new FileReader();

   reader.readAsDataURL(blob);

   reader.onload = function(e) {

  let a = document.createElement('a');

  a.download = fileName;

  a.href = e.target.result;

  document.body.appendChild(a);

  a.click();

  document.body.removeChild(a);

  }

}

You may also like

  • vestacp的文件管理插件免费了,给安装一个
  • 通过CSS 定义字母的大小写,drupal
  • 查看DISCUZ隐藏个人空间的发帖记录
  • xampp环境安装Drupal10提醒PHP OPcode caching 未启用
  • 也在win7的右键菜单栏上添加“在此处打开Powershell”方便composer
  • wordpress总更新受不了,避免总是更新一个插件就解决了
  • Discuz X3.4 搬站换空间过程
  • vestacp恢复备份文件ssh端命令