当前位置:   article > 正文

使用JavaScript将图片保存至本地_js保存图片名字

js保存图片名字

在最近的开发当中,我们需要为img标签以及canvas动态绘制的图像提供下载功能,下面是经过探索后我们得出的结果。

一、Canvas 版本

  1. // 下载Canvas元素的图片
  2. function downloadCanvasIamge(selector, name) {
  3. // 通过选择器获取canvas元素
  4. var canvas = document.querySelector(selector)
  5. // 使用toDataURL方法将图像转换被base64编码的URL字符串
  6. var url = canvas.toDataURL('image/png')
  7. // 生成一个a元素
  8. var a = document.createElement('a')
  9. // 创建一个单击事件
  10. var event = new MouseEvent('click')
  11. // 将a的download属性设置为我们想要下载的图片名称,若name不存在则使用‘下载图片名称’作为默认名称
  12. a.download = name || '下载图片名称'
  13. // 将生成的URL设置为a.href属性
  14. a.href = url
  15. // 触发a的单击事件
  16. a.dispatchEvent(event)
  17. }
  18. // 调用方式
  19. // 参数一: 选择器,代表canvas
  20. // 参数二: 图片名称,可选
  21. downloadCanvasIamge('canvas', '图片名称')

二、img 标签版本

  1. // 下载
  2. function downloadIamge(selector, name) {
  3. // 通过选择器获取img元素
  4. var img = document.querySelector(selector)
  5. // 将图片的src属性作为URL地址
  6. var url = img.src
  7. var a = document.createElement('a')
  8. var event = new MouseEvent('click')
  9. a.download = name || '下载图片名称'
  10. a.href = url
  11. a.dispatchEvent(event)
  12. }
  13. // 调用方式
  14. // 参数一: 选择器,代表img标签
  15. // 参数二: 图片名称,可选
  16. downloadIamge('canvas', '图片名称')

改进版

由于跨域会导致a标签在部分浏览器中会直接打开新标签页,所以改进如下

  1. function downloadIamge(selector, name) {
  2. var image = new Image()
  3. // 解决跨域 Canvas 污染问题
  4. image.setAttribute('crossOrigin', 'anonymous')
  5. image.onload = function () {
  6. var canvas = document.createElement('canvas')
  7. canvas.width = image.width
  8. canvas.height = image.height
  9. var context = canvas.getContext('2d')
  10. context.drawImage(image, 0, 0, image.width, image.height)
  11. var url = canvas.toDataURL('image/png')
  12. // 生成一个a元素
  13. var a = document.createElement('a')
  14. // 创建一个单击事件
  15. var event = new MouseEvent('click')
  16. // 将a的download属性设置为我们想要下载的图片名称,若name不存在则使用‘下载图片名称’作为默认名称
  17. a.download = name || '下载图片名称'
  18. // 将生成的URL设置为a.href属性
  19. a.href = url
  20. // 触发a的单击事件
  21. a.dispatchEvent(event)
  22. }
  23. image.src = document.querySelector(selector).src
  24. }
  25. // 调用方式
  26. // 参数一: 选择器,代表img标签
  27. // 参数二: 图片名称,可选
  28. downloadIamge('canvas', '图片名称')

三、总结

我们主要使用的是a标签的download属性, 下面为MDN给出的说明:

此属性指示浏览器下载URL而不是导航到URL,因此将提示用户将其保存为本地文件。
如果属性有一个值,它将在保存提示中用作预先填写的文件名 (用户仍然可以根据需要更改文件名)。对允许的值没有限制,但是/和\被转换为下划线。大多数文件系统限制文件名中的一些标点符号,浏览器会相应地调整建议的名称。

需要注意的地方:

  • 此属性仅适用于同源 URLs。
  • 可以使用 blob: URLs 和 data: URLs 以方便用户下载 JavaScript 方式生成的内容(例如使用在线绘图的Web应用创建的照片)。
  • 如果HTTP头的Content-Disposition:存在,并且赋予了一个和这个属性不同的文件名,HTTP头优先于此属性。
  • 如果这个属性存在 Content-Disposition 被设置为 inline,火狐优先 Content-Disposition,像之前文件名​​的情况下,而Chrome则优先 download 属性。
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/盐析白兔/article/detail/229327
推荐阅读
相关标签
  

闽ICP备14008679号