博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JS前端下载文本文件小技巧:1、download属性;2、借助Blob转换成二进制下载
阅读量:6038 次
发布时间:2019-06-20

本文共 2168 字,大约阅读时间需要 7 分钟。

一、HTML download 与文件下载

  如果希望在前端侧直接触发某些资源的下载,最方便快捷的方法就是使用HTML5原生的download属性,例如:

  但显然,如果纯粹利用HTML属性来实现文件的下载(而不是浏览器打开或浏览),对于动态内容,就无能为力。

  例如,我们对页面进行分享的时候,希望分享图片是页面内容的实时截图,此时,这个图片就是动态的,纯HTML显然是无法满足我们的需求的,借助JS和其它一些HTML5特性,例如,将页面元素转换到canvas上,然后再转成图片进行下载。

  是否支持download属性的监测:要监测当前浏览器是否支持download属性,一行JS代码就可以了,如下:

var isSupportDownload = 'download' in document.createElement('a');

二、借助HTML5 Blob实现文本信息文件下载

  原理其实很简单,我们可以将文本或者JS字符串信息借助Blob转换成二进制,然后,作为<a>元素的href属性,配合download属性,实现下载。

  代码也比较简单,如下示意(兼容Chrome和Firefox):

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指下载到系统中的文件名称

  触发下载的JS代码就几行:

button.addEventListener('click', function () {    funDownload(textarea.value, 'test.html');    });

  不止是.html文件,.txt.json等只要内容是文本的文件,都是可以利用这种小技巧实现下载的。

  在Chrome浏览器下,模拟点击创建的<a>元素即使不append到页面中,也是可以触发下载的,但是在Firefox浏览器中却不行,因此,上面的funDownload()方法有一个appendChildremoveChild的处理,就是为了兼容Firefox浏览器。

  实例:

var eleTextarea = document.querySelector('textarea');var eleButton = document.querySelector('input[type="button"]');// 下载文件方法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);};if ('download' in document.createElement('a')) {    // 作为test.html文件下载    eleButton.addEventListener('click', function () {        funDownload(eleTextarea.value, 'test.html');        });} else {    eleButton.onclick = function () {        alert('浏览器不支持');        };}

总结:

1、download属性下载文件:download="文件路径"

2、Blob二进制转换:new Blob([content]),以及二进制路径转换:URL.createObjectURL(new Blob([content]))

转载地址:http://xlohx.baihongyu.com/

你可能感兴趣的文章
Azure运维系列 6:使用自定义映像创建虚拟机
查看>>
puppet成长日记二 Package资源详细介绍及案例分析
查看>>
AE+C# 向axPageLayoutControl1添加图例
查看>>
Hive Streaming 追加 ORC 文件
查看>>
打开Apache自带的Web监视器
查看>>
企业 SOA 设计(2)–组件化产品开发平台
查看>>
在笛卡尔坐标系上描绘函数2*x+Math.sqrt(5-x*x)及其共轭函数2*x-Math.sqrt(5-x*x)曲线
查看>>
Solr常用查询语法笔记
查看>>
EBS R11i,R12 导入导出数据库迁移(10g,11g) 以及 R11i, R12 数据库相关文档
查看>>
2015年第13本(英文第9本):Murder on the Orient Express 东方快车谋杀案
查看>>
串口硬流控原理验证RTS与CTS
查看>>
BackTracking_Fixed sum for array elements
查看>>
[转] C#操作Excel文件
查看>>
为什么选择adodb而不用pdo
查看>>
Azure SQL Database (25) Azure SQL Database创建只读用户
查看>>
python 如何使用pip安装第三方软件
查看>>
Hadoop不适合处理实时数据的原因剖析
查看>>
Azure PowerShell (1) PowerShell入门
查看>>
Node.js的静态页面想通过jQuery的Ajax函数调用远程服务的措施无效
查看>>
深刻理解C#的传值调用和传引用调用
查看>>