整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:

使用JavaScript将图片保存至本地

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

一、Canvas 版本

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

二、img 标签版本

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

改进版

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

function downloadIamge(selector, name) {
 var image = new Image()
 // 解决跨域 Canvas 污染问题
 image.setAttribute('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.createElement('a')
 // 创建一个单击事件
 var event = new MouseEvent('click')
 // 将a的download属性设置为我们想要下载的图片名称,若name不存在则使用‘下载图片名称’作为默认名称
 a.download = name || '下载图片名称'
 // 将生成的URL设置为a.href属性
 a.href = url
 // 触发a的单击事件
 a.dispatchEvent(event)
}
image.src = document.querySelector(selector).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 属性。



将网页转换为图片,您可以使用一些库和工具来实现。在前端开发中,常用的库包括html2canvas和dom-to-image。这些库允许您将HTML元素转换为图像。

下面是使用html2canvas库将网页转换为图像的示例代码:

<!DOCTYPE html>  
<html>  
<head>  
  <title>Convert Webpage to Image</title>  
  <script src="https://cdnjs.cloudflare.com/ajax/libs/html2canvas/1.3.2/html2canvas.min.js"></script>  
</head>  
<body>  
  <div id="capture">  
    <!-- 在这里放置您想要转换为图像的HTML内容 -->  
    <h1>Hello, World!</h1>  
    <p>This is an example of converting a webpage to an image.</p>  
  </div>  
  
  <button onclick="convertToImage()">Convert to Image</button>  
  
  <script>  
    function convertToImage() {  
      html2canvas(document.getElementById("capture")).then(canvas => {  
        var img = canvas.toDataURL("image/png");  
        var link = document.createElement("a");  
        link.href = img;  
        link.download = "webpage.png";  
        link.click();  
      });  
    }  
  </script>  
</body>  
</html>

上述代码使用html2canvas库来将id为"capture"的div元素转换为图像。当用户点击"Convert to Image"按钮时,convertToImage()函数会被调用。该函数使用html2canvas对指定的HTML元素进行截图,并将结果转换为一个包含图像数据的URL。然后,创建一个隐藏的链接元素,将图像数据URL设置为链接的href属性,并模拟点击该链接以下载图像。最后,图像将以PNG格式下载到用户的设备上。

请注意,html2canvas库有一些限制和局限性,例如跨域图像的限制、CSS样式的复杂性等。确保在使用这些库时仔细测试和验证您的代码,并查阅相关文档以了解更多细节和选项。

秒get!用JS代码下载公众号封面图片,简单又高效!

大家好,今天给大家带来一个非常实用的小技巧——如何使用一段JS代码当做书签来下载公众号的封面图片!是不是听起来很高大上?其实操作起来非常简单,看完这篇文章,你也能轻松搞定!

为什么要下载公众号封面图片?

先来说说为什么我们需要下载公众号的封面图片。作为一个公众号运营者,或者一个公众号文章的狂热粉丝,有时候我们会看到一些非常精美的封面图片,忍不住想要保存下来。

不仅可以用作素材,还可以欣赏这么漂亮的图片嘛!然而,有些公众号图片没有放到正文里面,也是不能直接右键保存的,这时候就需要一点小技巧啦!

硬核技术解析

别急,看到“技术”两个字不要害怕,其实非常简单!我们要用到一段JS代码,这段代码会在网页上生成一个按钮,点击这个按钮就能下载封面图片。是不是听起来很酷炫?

JS代码的秘密

我不会把完整的代码贴出来,直接讲解一下它的原理:

  1. 1. 创建按钮:首先,这段代码会创建一个按钮,样式也很漂亮,绿色背景、白色文字,非常醒目。
  2. 2. 按钮功能:当你点击这个按钮时,代码会找到封面图片的地址,然后下载图片并保存到你的电脑上。

听起来简单吧?那我们就开始实际操作吧!

如何操作?

下面是具体的操作步骤,跟着做,保证你能成功!

第一步:将代码保存为书签

  1. 打开你的浏览器(这里我们以Chrome为例)。
  2. 在浏览器的书签栏上点击右键,选择“添加网页”。

  1. 给这个书签取个名字,比如“下载公众号封面”。
  2. 在“网址”一栏,粘贴上面的JS代码:
javascript:(function(){var metaContentElement=document.getElementById('meta_content_hide_info');var newTag=document.createElement('span');newTag.style.position='initial';newTag.style.right='10px';newTag.style.top='10px';newTag.style.backgroundColor='#4CAF50';newTag.style.color='#fff';newTag.style.padding='5px';newTag.style.borderRadius='5px';newTag.style.cursor='pointer';newTag.style.fontSize='12px';newTag.textContent='下载封面图片';newTag.onclick=function(){var ogImageMeta=document.querySelector('meta[property="og:image"]');var ogTitleMeta=document.querySelector('meta[property="og:title"]');if(ogImageMeta){var imageUrl=ogImageMeta.content;var fileName=getValidFileName(ogTitleMeta?ogTitleMeta.content:null);fetchAndDownloadImage(imageUrl,fileName);}else{alert('没有找到og:image标签');}};metaContentElement.parentNode.insertBefore(newTag,metaContentElement.nextSibling);function getValidFileName(ogTitle){if(ogTitle&&ogTitle.trim().length>0){return ogTitle.trim();}return'cover_image';}function fetchAndDownloadImage(url,fileName){fetch(url).then(response=>response.blob()).then(blob=>{const blobUrl=window.URL.createObjectURL(blob);const a=document.createElement('a');a.href=blobUrl;a.download=fileName;document.body.appendChild(a);a.click();document.body.removeChild(a);window.URL.revokeObjectURL(blobUrl);}).catch(error=>console.error('Error downloading image:',error));}})();

5. 点击保存。

第二步:使用书签下载封面图片

  1. 打开你想要下载封面图片的公众号文章页面。
  2. 点击刚才保存的书签。
  3. 页面上会出现一个新的按钮,写着“下载封面图片”。
  4. 点击这个按钮,封面图片就会自动下载到你的电脑上了!

小结

怎么样,是不是非常简单?只需要几步操作,你就能轻松下载公众号的封面图片了!这个小技巧不仅适合技术小白,也非常实用。下次看到喜欢的封面图片,再也不用愁了!

希望这篇文章对你有帮助,赶快去试试吧!如果你觉得这个技巧有用,点赞就行,自己偷偷用!