• https://www.awaimai.com/259.html

页面上有一段代码,要保存下来,怎么做?

选择复制?用按钮请求数据库?都很低效。

既然页面已经有了内容,为何不用JS获取这段代码,生成文件后直接下载?

下面我们用 BlobURL.createObjectURL 来实现这一功能,兼容Chrome、Firefox和IE等主流浏览器。

1 演示

点击查看演示地址。

2 实现代码

JS代码如下,已经封装成一个函数,filename是保存的文件名,content是保存到这个文件中的内容:

function download(filename, content) {
    var blob = new Blob([content], {type: 'text/plain'});
    var url = window.URL.createObjectURL(blob);
    var a = document.createElement('a');

    a.style = "display: none";
    a.href = url;
    a.download = filename;
    document.body.appendChild(a);
    a.click();

    setTimeout(function () {
        document.body.removeChild(a);
        window.URL.revokeObjectURL(url);
    }, 5);
}

这部分点实现步骤是:

  1. 先创建一个blob类文本对象(Binary large object),用它来虚拟表示一个文件。
  2. 再用 window.URL.createObjectURL 来生成blob对象URL。这个对象URL是一个DOMString,可以用在 href 和 src 之类的属性上。
  3. 创建一个隐藏的 <a> 标签。
  4. 设置 <a> 标签的 href 和 download 属性。
  5. 触发这个 <a> 标签的 click 事件,实现下载。
  6. 用setTimeout()延时一小段时间,让click()事件充分响应。
  7. 延时过后,revokeObjectURL 释放由 createObjectURL 创建的 object URL。当该 object URL 不需要的时候,我们要主动调用这个方法,获取最佳性能和内存使用。

3 点击下载

然后,我们可以添加一个按钮,点击事件下载文件:

按钮:

<button type="button" id="down">Download</button>

点击事件:

document.getElementById('down').onclick = function () {
    var filename = "justdown.txt";
    var content = "Hello, you download a text file by Javasctipt.";
    download(filename, content);
};

相关文章:

  1. 《使用HTML5来实现本地文件读取和写入》
  2. 《js读取文件内容》

参考文章:

  1. 如何用 JavaScript 下载文件
  2. Blob createObjectURL download not working in Firefox (but works when debugging)
  3. 在浏览器端用JS创建和下载文件