本文转载自:www.zhangxinxu.com/wordpress/?…html
若是但愿在前端侧直接触发某些资源的下载,最方便快捷的方法就是使用HTML5原生的download
属性,例如:前端
<a href="large.jpg" download>下载</a>复制代码
具体介绍可参考我以前的文章:“了解HTML/HTML5中的download属性”。json
但显然,若是纯粹利用HTML属性来实现文件的下载(而不是浏览器打开或浏览),对于动态内容,就无能为力。canvas
例如,咱们对页面进行分享的时候,但愿分享图片是页面内容的实时截图,此时,这个图片就是动态的,纯HTML显然是没法知足咱们的需求的,借助JS和其它一些HTML5特性,例如,将页面元素转换到canvas
上,而后再转成图片进行下载,可参见“SVG <foreignObject>简介与截图等应用”一文。浏览器
但本文要介绍的下载不是图片的下载,而是文本信息的下载,所须要使用的HTML特性不是canvas
,而是其它。bash
若是对Blob不了解,能够先看看我好些年以前写的“理解DOMString、Document、FormData、Blob、File、ArrayBuffer数据类型”一文。app
原理其实很简单,咱们能够将文本或者JS字符串信息借助Blob转换成二进制,而后,做为<a>
元素的href
属性,配合download
属性,实现下载。dom
代码也比较简单,以下示意(兼容Chrome和Firefox):svg
var funDownload = function (content, filename) {
// 建立隐藏的可下载连接
var eleLink = document.createElement('a');
eleLink.download = filename;
eleLink.style.display = 'none';
// 字符内容转变成blob地址
var blob = new Blob([content]);
eleLink.href = URL.createObjectURL(blob);
// 触发点击
document.body.appendChild(eleLink);
eleLink.click();
// 而后移除
document.body.removeChild(eleLink);
};复制代码
其中,content
指须要下载的文本或字符串内容,filename
指下载到系统中的文件名称。wordpress
万般言语不达意,一枚实例来走心。
您能够狠狠地点击这里:基于funDownload实现的html格式文件下载demo
点击“下载”按钮,会把文本域中的内容所有做为一个.html
后缀文件下载下来,各流程效果以下面几张图:
出现下载确认框(根据浏览器的设置不一样也可能直接下载),而后名称默认就是test.html
。
而后对应保存目录就多了个相似下图的文件:
双击该test.html
文件能够在浏览器中正常浏览,说明,保存信息无误。
触发下载的JS代码就几行:
button.addEventListener('click', function () {
funDownload(textarea.value, 'test.html');
});复制代码
对于非文本文件,也是能够直接JS触发下载的,例如,若是咱们想下载一张图片,能够把这张图片转换成base64格式,而后下载。
代码示意:
var funDownload = function (domImg, filename) {
// 建立隐藏的可下载连接
var eleLink = document.createElement('a');
eleLink.download = filename;
eleLink.style.display = 'none';
// 图片转base64地址
var canvas = document.createElement('canvas');
var context = canvas.getContext('2d');
var width = domImg.naturalWidth;
var height = domImg.naturalHeight; context.drawImage(domImg, 0, 0);
// 若是是PNG图片,则canvas.toDataURL('image/png')
eleLink.href = canvas.toDataURL('image/jpeg');
// 触发点击
document.body.appendChild(eleLink);
eleLink.click();
// 而后移除
document.body.removeChild(eleLink);
};复制代码
不止是.html
文件,.txt
, .json
等文本文件均可以使用这种小技巧实现下载。
在Chrome浏览器下,模拟点击建立的<a>
元素即便不append
到页面中,也是能够触发下载的,可是在Firefox浏览器中却不行,所以,上面的funDownload()
方法有一个appendChild
和removeChild
的处理,就是为了兼容Firefox浏览器。
download
属性从Edge13开始支持,根据同行测试能够触发下载,不过生成的文件命名相似GUID,须要手动再加个后缀。
就这些,感谢阅读!