摘要:最近项目中需要实现一个下载图片的功能如下图一开始考虑使用标签的属性进行下载图片下载海报下载海报但是通过测试,发现再中,下载的文件不能带上拓展名,所以只好换一个思路,使用进行处理。
最近项目中需要实现一个下载图片的功能(如下图)
一开始考虑使用a标签的download属性进行下载:
下载海报
但是通过测试,发现再safari中,下载的文件不能带上拓展名,所以只好换一个思路,使用canvas进行处理。
1.图片需要添加crossOrigin="anonymous"设置图像的跨域属性
img.crossOrigin = "anonymous";
2.使用toDataURL把图片转换成base64格式
canvas.toDataURL("image/png")
3.使用模拟点击事件,触发下载
var save_link = document.createElement("a"); save_link.href = image; save_link.download ="测试.png"; var clickevent = document.createEvent("MouseEvents"); clickevent.initEvent("click", true, false); save_link.dispatchEvent(clickevent);
完整代码:
var canvas = $(".canvas"); var cxt = canvas[0].getContext("2d"); function save(){ var img = new Image(); img.crossOrigin = "anonymous"; img.onload = function(){ var _w = img.naturalWidth; var _h = img.naturalHeight; canvas.attr({width:_w,height:_h}); cxt.drawImage(img,0,0); var image = canvas[0].toDataURL("image/png") var save_link = document.createElement("a"); save_link.href = image; save_link.download ="测试.png"; var clickevent = document.createEvent("MouseEvents"); clickevent.initEvent("click", true, false); save_link.dispatchEvent(clickevent); }; img.src = "http://n.sinaimg.cn/sports/transform/20170825/NZI3- fykiufe6650492.jpg"; }
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/51162.html
摘要:本次技术调研来源于项目中的一个重要功能需求实现微信长按网页保存为截图。小结是目前实现网页保存为图片功能的综合最佳选择。 本次技术调研来源于H5项目中的一个重要功能需求:实现微信长按网页保存为截图。 这里有个栗子(请用微信打开,长按图片即可保存):3分钟探索你的知识边界 将整个网页保存为图片是一个十分有趣的功能,常见于H5活动页的结尾页分享。以下则是项目中调研和踩坑的一些小结和汇总。 ...
摘要:本次技术调研来源于项目中的一个重要功能需求实现微信长按网页保存为截图。小结是目前实现网页保存为图片功能的综合最佳选择。 本次技术调研来源于H5项目中的一个重要功能需求:实现微信长按网页保存为截图。 这里有个栗子(请用微信打开,长按图片即可保存):3分钟探索你的知识边界 将整个网页保存为图片是一个十分有趣的功能,常见于H5活动页的结尾页分享。以下则是项目中调研和踩坑的一些小结和汇总。 ...
摘要:本次技术调研来源于项目中的一个重要功能需求实现微信长按网页保存为截图。小结是目前实现网页保存为图片功能的综合最佳选择。 本次技术调研来源于H5项目中的一个重要功能需求:实现微信长按网页保存为截图。 这里有个栗子(请用微信打开,长按图片即可保存):3分钟探索你的知识边界 将整个网页保存为图片是一个十分有趣的功能,常见于H5活动页的结尾页分享。以下则是项目中调研和踩坑的一些小结和汇总。 ...
摘要:本次技术调研来源于项目中的一个重要功能需求实现微信长按网页保存为截图。以下主要解决两类跨域的图片资源包括已配置过的中的图片资源和微信用户头像图片资源。 本次技术调研来源于H5项目中的一个重要功能需求:实现微信长按网页保存为截图。 这里有个栗子(请用微信打开,长按图片即可保存):3分钟探索你的知识边界 将整个网页保存为图片是一个十分有趣的功能,常见于H5活动页的结尾页分享。以下则是项目中...
摘要:本次技术调研来源于项目中的一个重要功能需求实现微信长按网页保存为截图。以下主要解决两类跨域的图片资源包括已配置过的中的图片资源和微信用户头像图片资源。 本次技术调研来源于H5项目中的一个重要功能需求:实现微信长按网页保存为截图。 这里有个栗子(请用微信打开,长按图片即可保存):3分钟探索你的知识边界 将整个网页保存为图片是一个十分有趣的功能,常见于H5活动页的结尾页分享。以下则是项目中...
摘要:本次技术调研来源于项目中的一个重要功能需求实现微信长按网页保存为截图。以下主要解决两类跨域的图片资源包括已配置过的中的图片资源和微信用户头像图片资源。 本次技术调研来源于H5项目中的一个重要功能需求:实现微信长按网页保存为截图。 这里有个栗子(请用微信打开,长按图片即可保存):3分钟探索你的知识边界 将整个网页保存为图片是一个十分有趣的功能,常见于H5活动页的结尾页分享。以下则是项目中...
阅读 1103·2021-11-08 13:13
阅读 1688·2019-08-30 15:55
阅读 2725·2019-08-29 11:26
阅读 2410·2019-08-26 13:56
阅读 2524·2019-08-26 12:15
阅读 2093·2019-08-26 11:41
阅读 1373·2019-08-26 11:00
阅读 1514·2019-08-23 18:30