在最近的开发当中,我们需要为img标签以及canvas动天真的孩子态绘制的图像提供下载功能,下面是经过探索后我们得出的结果。
一、canvas 版本
// 下载canvas元素的图片function downloadcanvasiamge(lector, name) { // 通过选择器获取canvas元素 var canvas = document.querylector(lector) // 使用todataurl方法将图像转换被ba64编码的url字符串 var url = canvas.todataurl('image/png') // 生关于端午的诗句成一个a元素 var a = document.crea职业大学排行榜teelement('a') // 创建一个单击事件 var event = new mouevent('click') // 将a的download属性设置为我们想要下载的图片名称,若name不存在则使用‘下载图片名称’作为默认名称 a.download = name || '下载图片名称' // 将生成的url设置为a.href属性 a.href = url // 触发a的单击事件 a.dispatchevent(event)}// 调用方式// 参数一: 选择器,做啥赚钱代表canvas// 参数二: 图片名称,可选downloadcanvasiamge('canvas', '图片名称')
二、img 标签版本
// 下载function downloadiamge(lector, name) { // 通过选择器获取img元素 var img = document.querylector(lector) // 将图片的src属性作为url地址 var url = img.src var a = document.createelement('a') var event = new mouevent('click') a.download = name || '下载图片名称' a.href = url a.dispatchevent(event)}// 调用方式// 参数一: 选择器,代表img标签// 参数二: 图片名称,可选downloadiamge('canvas', '图片名称')
改进版
由于跨域会导致a标签在部分浏览器中会直接打开新标签页,所以改进如下
function downloadiamge(lector, name) { var image = new image() // 解决跨域 canvas 污染问题 image.tattribute('crossorigin', 'anonymous') image.onload = function () { var canvas = document.createelement('canvas') canvas.width = image.width canvas.height = image.height var context = canvas.getcontext('2d') context.drawimage(image, 0, 0, image.width, image.height) var url = canvas.todataurl('image/png') // 生成一个a元素 var a = document.createe葡萄沟教学设计lement('a') // 创建一个单击事件 var event = new mouevent('click') // 将a的download属性设置为我们想要下载的图片名称,若name不存在则使用‘下载图片名称’作为默认名称 a.download = name || '下载图片名称' // 将生成的url设置为a.href属性 a.href = url // 触发a的单击事件 a.dispatchevent(event)}image.src = document.querylector(lector).src}// 调用方式// 参数一: 选择器,代表img标签// 参数二: 图片名称,可选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 属性。
本文发布于:2023-04-05 08:41:27,感谢您对本站的认可!
本文链接:https://www.wtabcd.cn/fanwen/zuowen/dac35a3082ef316903eaa26ae7bd2d3e.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文word下载地址:js保存图片到手机相册怎么保存(js实现下载文件到本地).doc
本文 PDF 下载地址:js保存图片到手机相册怎么保存(js实现下载文件到本地).pdf
留言与评论(共有 0 条评论) |