// ==UserScript== // @name 图片下载器 // @namespace http://tampermonkey.net/ // @version 3.2.3 // @description 批量下载图片,一个可扩展的图片下载器。 // @author Gscsd // @include * // @icon  // @grant GM_xmlhttpRequest // @grant GM_download // @grant GM_setValue // @grant GM_log // @grant GM_notification // @connect * // @require https://cdn.bootcdn.net/ajax/libs/jquery/3.6.0/jquery.min.js // @require https://cdn.bootcdn.net/ajax/libs/jszip/3.7.1/jszip.js // @run-at document-end // @noframes // @downloadURL none // ==/UserScript== (function () { 'use strict'; function depthTest(fa, a) { var sum = 0; while (1) { if (a === fa) break; a = $(a).parent()[0]; sum++; } return sum } function FindBrothers(a) { let par = $(a).parent()[0], sea = $(par).find('img').toArray(); if (sea.length === 1) return FindBrothers(par) else { let depth = depthTest(par, getimg), sea1 = []; sea.forEach((item) => { if (depthTest(par, item) === depth) sea1.push(item) }) sea = sea1; if (sea.length === 1) return FindBrothers(par); return sea } } //重写下载函数 /*function GM_download(url, name) { let a = document.createElement('a') a.download = name a.href = url a.style.display = 'none' document.body.appendChild(a) a.click() a.remove() }*/ class TaskQueue { downloadIndex = 0; retryIndex = 0; results = []; transfer = []; error = []; //0未下载 1下载排队中 2下载排队完成,等待中 3下载成功 4下载失败 5下载完成 downloadStatus = 0 constructor(o) { if ($('#v_bar').length) { GM_notification({text: '下载中,请稍等...', timeout: 3000}) return } /* api: TaskQueue(details) 图片下载类。 Property of details: imglist: 图片下载链接列表,默认[],必选; thread: 启用下载线程,默认10; retryNum: 下载出错,重试次数,默认5; filename: 打包zip文件名,默认当前网站标题(稍做处理); timeout: 单张图片请求超时,默认60 * 1000ms,即1min; autoRetry: 下载出错自动重试,默认false; autoDownload: 重试失败后自动下载,默认false; onload: 成功回调,默认null; onerror: 失败回调,默认null。 e.g. let imglist = document.querySelectorAll('.normal-img'), Imglist = [] let len = imglist.length; for (let i = 0; i < len; i++) { Imglist.push(new URL(imglist[i].getAttribute('data-src').split('@')[0], location.href).href) } setTimeout(_ => { if (len >= 2) { if (confirm(`下载全部${len}张图片?`)) { new TaskQueue({ imglist: Imglist, filename: document.title.split('-')[0].trim() }); } } }, 2000) more: 1.启用本下载器后,超链接跳转在下载未完成或手动取消前将被禁止,请务必在不需要时关闭本下载器; 2.仅支持zip批量打包下载,兼容移动端kiwi浏览器; 3.请允许跨域图片下载权限; 4.若蓝色下载进度条,超过默认超时时间仍卡死,请刷新重试; 5.由于现在不少网站使用了lazyload技术,不一定能获取到图片链接,所以最好从头划到尾,等图片加载后再下载; 6.若普通点击,无法捕获到图片,启动下载,可按照上api自行适配; 7.学艺不精,水平有限,内行勿笑。 */ ({ imglist: this.queue = [], thread: this.thread = 10, retryNum: this.retryNum = 5, filename: this.filename = document.title.replace(/- .*?$/, '').trim(), //请求超时 timeout: this.timeout = 60 * 1000, //自动重试 autoRetry: this.autoRetry = false, //重试失败后自动下载 autoDownload: this.autoDownload = false, //成功回调 onload: this.onload = null, //失败回调 onerror: this.onerror = null } = o); this.progressList = Array(this.queue.length) $('body').append(`