爱采购

发产品

  • 发布供应
  • 管理供应
使用 JS 的 download 库来下载资源使用 JS 的 download 库来下载资源_PHP 教程_软件编程_教程资讯_大秦朝旭-码农学习站

使用 JS 的 download 库来下载资源

   2023-10-03 126 0
导读

HTML5 a 标签可以使用 download 属性来设置资源的下载,但需要是同源,如果浏览器可以解析也会直接打开。这时我们可以通过第三方

HTML5 a 标签可以使用 download 属性来设置资源的下载,但需要是同源,如果浏览器可以解析也会直接打开。

这时我们可以通过第三方库 download 来实现更完整的下载功能。

download.js 相关资源:

download.js 库提供了 download() 函数用于下载文件。

下载内容可以是 URL、字符串、Blob 或类型化的数据数组,或者通过将文件数据表示为 base64 或 url 编码字符串的 dataURL。

无论输入格式如何,download() 都使用指定的文件名和 mime 信息以与使用 Content-Disposition HTTP 标头的服务器相同的方式保存文件。

download(data, strFileName, strMimeType);
  • data - 下载的数据内容,可以是 Blob、File、String 或 dataURL。
  • strFileName - 要创建的文件的名称。
  • strMimeType - 要下载的文件的 MIME 内容类型。

实例

文本

将字符串存储到 dlText.txt 文件中并下载:

download("hello world", "dlText.txt", "text/plain");

dataURL 文本实例:

download("data:text/plain,hello%20world", "dlDataUrlText.txt", "text/plain");

blob 文本实例:

download(new Blob(["hello world"]), "dlTextBlob.txt", "text/plain");

url 实例:

download("/robots.txt");

UInt8 文本数组实例:

var str= "hello world",    arr= new Uint8Array(str.length);str.split("").forEach(function(a,b){
  arr[b]=a.charCodeAt();});download( arr, "textUInt8Array.txt", "text/plain" );

HTML

html 字符串实例:

download(document.documentElement.outerHTML, "dlHTML.html", "text/html");

html Blob 实例:

download(new Blob(["hello world".bold()]), "dlHtmlBlob.html", "text/html");

ajax 回调实例:

$.ajax({        url: "/download.html",        success: download.bind(true, "text/html", "dlAjaxCallback.html")});

二进制文件

图片 URL:

download("/diff6.png");

异步下载图片:

var x=new XMLHttpRequest();x.open( "GET", "/diff6.png" , true);x.responseType="blob";x.onload= function(e){download(e.target.response, "awesomesauce.png", "image/png");};x.send();


 
反对 0举报 0 收藏 0 打赏 0评论 0
免责声明
• 
本文为会员q2597758发布,欢迎转载,转载请注明原文出处:http://www.52419.net/news/show-48.html 。本文仅代表作者个人观点,本站未对其内容进行核实,请读者仅做参考,如若文中涉及有违公德、触犯法律的内容,一经发现,立即删除,作者需自行承担相应责任。涉及到版权或其他问题,请及时联系我们。
 
更多>同类PHP 教程

入驻

企业入驻成功 可尊享多重特权

入驻热线:17792038992

请手机扫码访问

客服

客服热线:17792038992

小程序

小程序更便捷的查找产品

为您提供专业帮买咨询服务

请用微信扫码

公众号

微信公众号,收获商机

微信扫码关注

顶部