1.使用场景

对浏览器 识别/不识别 的文件下载

2.核心代码

  1. var eleTextarea = document.querySelector('textarea');
  2. var eleButton = document.querySelector('input[type="button"]');
  3.  
  4. // 下载文件方法
  5. var funDownload = function (content, filename) {
  6. var eleLink = document.createElement('a');
  7. eleLink.download = filename;
  8. eleLink.style.display = 'none';
  9. // 字符内容转变成blob地址
  10. var blob = new Blob([content]);
  11. eleLink.href = URL.createObjectURL(blob);
  12. // 触发点击
  13. document.body.appendChild(eleLink);
  14. eleLink.click();
  15. // 然后移除
  16. document.body.removeChild(eleLink);
  17. };
  18.  
  19. if ('download' in document.createElement('a')) {
  20. // 作为test.html文件下载
  21. eleButton.addEventListener('click', function () {
  22. funDownload(eleTextarea.value, 'test.html');
  23. });
  24. } else {
  25. eleButton.onclick = function () {
  26. alert('浏览器不支持');
  27. };
  28. }

图片下载

  1. function downloadIamge(imgsrc, name) { //下载图片地址和图片名
  2. let image = new Image();
  3. // 解决跨域 Canvas 污染问题
  4. image.setAttribute("crossOrigin", "anonymous");
  5. image.onload = function () {
  6. let canvas = document.createElement("canvas");
  7. canvas.width = image.width;
  8. canvas.height = image.height;
  9. let context = canvas.getContext("2d");
  10. context.drawImage(image, 0, 0, image.width, image.height);
  11. let url = canvas.toDataURL("image/png"); //得到图片的base64编码数据
  12. let a = document.createElement("a"); // 生成一个a元素
  13. let event = new MouseEvent("click"); // 创建一个单击事件
  14. a.download = name || "photo"; // 设置图片名称
  15. a.href = url; // 将生成的URL设置为a.href属性
  16. a.dispatchEvent(event); // 触发a的单击事件
  17. };
  18. image.src = imgsrc;
  19. }

3.兼容性

4.参考链接

download 属性的更多相关文章

  1. HTML <a> download 属性,点击链接来下载图片

    Html5里面的 标签的 Download 属性可以设置一个值来规定下载文件的名称.所允许的值没有限制,浏览器将自动检测正确的文件扩展名并添加到文件 (.img, .pdf, .txt, .html, ...

  2. JS/HTML 保存图片到本地:HTML <a> download 属性

    JS如何保存图片到本地呢?自己百度一下吧! 这里想要说的是,可以利用 HTML 的 <a> 标签 来是实现保存图片到本地的功能,参考代码如下: <a href="http: ...

  3. HTML5 <a>标签download 属性

    一.简单实例 <a href="../images/1.jpg" download="下载图片.jpg"> 点击按钮下载 </a> 二. ...

  4. 了解HTML/HTML5中的download属性

    一.download属性是个什么鬼? 首先看下面这种截图: 如果我们想实现点击上面的下载按钮下载一张图片,你会如何实现? 我们可能会想到一个最简单的方法,就是直接按钮a标签链接一张图片,类似下面这样: ...

  5. HTML5 a标签的download属性

    介绍一个HTML5的新特性 a标签的download属性: 目前市场上面支持的浏览器有限: html: <!DOCTYPE html> <html> <body> ...

  6. jQuery --- 利用a标签的download属性下载文件!

    最近遇到一个项目,需要有点击下载文件的功能. 由于文件格式是多种的,对于 rar / zip / rtf / doc / xlsx / jpg等. 点击下载有的是直接跳转到后进行下载,但有的是打开进行 ...

  7. JS前端下载文本文件小技巧:1、download属性;2、借助Blob转换成二进制下载

    一.HTML download 与文件下载 如果希望在前端侧直接触发某些资源的下载,最方便快捷的方法就是使用HTML5原生的download属性,例如: <a href="large. ...

  8. 火狐 a 标签 download 属性,要在 a 标签添加到页面中才生效;

    在 chrome 中,如果需要设置点击下载文件,需要创建一个 a 标签,指定 download 属性和 href 属性即可, var aLink = document.createElement('a ...

  9. a标签的download属性简介

    最近在工作中需要一个前端直接下载静态文件的需求,之前有粗略的了解过a标签的download属性,通过download和href属性可以实现文件的下载. 简介 HTML <a> 元素 (或锚 ...

  10. html/html5中的download属性

    兼容性不是很好, 只是了解一下: 主要表现在跨域策略的处理上,Chrome浏览器和FireFox浏览器: 如果需要下载的资源是跨域的,包括跨子域,在Chrome浏览器下,使用download属性是可以 ...

随机推荐

  1. mycat基本概念及配置文件详解

    在介绍mycat之前,首先来了解一下数据库切分. 对于海量数据处理,按照使用场景,主要分为两类:联机事务处理(OLTP)和联机分析处理(OLAP). 联机事务处理也称为面向交易的处理系统,其基本特征是 ...

  2. mysql 5.7/percona server/mariadb 10.2安装与服务器参数优化

    建议使用percona server linux generic版,从https://www.percona.com/downloads/Percona-Server-LATEST/下载,现在不在推荐 ...

  3. unknown variable 'log_bin_basename'

    今天在处理一问题时,在my.cnf中设置了log_bin_basename=/DATA/log-bin,在启动时报unknown variable 'log_bin_basename' 经查mysql ...

  4. Linear Regression with PyTorch

    Linear Regression with PyTorch Problem Description 初始化一组数据 \((x,y)\),使其满足这样的线性关系 \(y = w x + b\) .然后 ...

  5. XXX银行项目部署

    XXX银行项目部署 一.下载项目代码 1.使用git工具下载代码 代码路径:推荐代码下载到桌面 git clone http://sunyard_姓名拼音@bitbucket.devops.hfdev ...

  6. py4CV例子2汽车检测和svm算法

    1.什么是汽车检测数据集: ) pos, neg = , ) matcher = cv2.FlannBasedMatcher(flann_params, {}) bow_kmeans_trainer ...

  7. TensorFlow模型保存和加载方法

    TensorFlow模型保存和加载方法 模型保存 import tensorflow as tf w1 = tf.Variable(tf.constant(2.0, shape=[1]), name= ...

  8. bzoj 1304 [CQOI 2009] 叶子的染色 - 动态规划

    题目传送门 快速的传送门 慢速的传送门 题目大意 给定一棵无根树,每个点可以染成黑色或者白色,第$i$叶节点到根的路径上最后有颜色的点必须为$c_{i}$(叶节点可以染色).问最少要染颜色的点的个数. ...

  9. javaScript中ajax、axios总结

    一.原生js实现ajax请求: 步骤: get请求: // 1.创建一个XMLHttpRequest的对象. var xml=null; //初始值设为空 if(XMLHttpRequest){ xm ...

  10. VC++ 利用PDB和dump文件定位问题并进行调试

    转载:https://blog.csdn.net/zfs_kuai/article/details/43646665 转载:https://blog.csdn.net/i_chaoren/articl ...