当前页面的图片一键下载(必须等网页加载完成之后)
// ==UserScript==
// @name 图片采集下载
// @namespace http://tampermonkey.net/
// @version 0.3
// @description 当前页面的图片一键下载(必须等网页加载完成之后)
// @author You
// @match http://*/*
// @match https://*/*
// @User-Agent Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/90.0.4430.212 Safari/537.36
// @icon 
// @grant none
// ==/UserScript==
(function() {
'use strict';
let button = document.createElement('button')
button.innerText= '采集'
button.style.backgroundColor= 'red'
button.style.color = '#ffffff'
button.style.fontWeight = 'bold'
button.style.position = 'fixed'
button.style.padding = '10px 16px'
button.style.top = '0'
button.style.right = '0'
button.style.zIndex = '99999999'
button.style.borderRadius = '4px'
button.style.border = "2px solid red"
button.style.opacity = "1"
document.body.appendChild(button)
button.onclick = function(){
imgdown(downFile)
}
function downFile(imgsrc, name) { //下载图片地址和图片名
let image = new Image();
// 解决跨域 Canvas 污染问题
image.setAttribute("crossOrigin", "anonymous");
image.onload = function () {
let canvas = document.createElement("canvas");
canvas.width = image.width;
canvas.height = image.height;
let context = canvas.getContext("2d");
context.drawImage(image, 0, 0, image.width, image.height);
let url = canvas.toDataURL("image/png"); //得到图片的base64编码数据
let a = document.createElement("a"); // 生成一个a元素
let event = new MouseEvent("click"); // 创建一个单击事件
a.download = name || "photo"; // 设置图片名称
a.href = url; // 将生成的URL设置为a.href属性
a.dispatchEvent(event); // 触发a的单击事件
};
image.src = imgsrc;
}
function imgdown(callback) {
Array.from(document.images).forEach((element, i) => {
callback("https://images.weserv.nl/?url="+element.currentSrc, i)
});
}
})();