// ==UserScript== // @name 1688-莫知 // @version 1.0 // @namespace http://tampermonkey.net/ // @description 爬图片 // @author 莫知 // @license MIT // @match https://detail.1688.com/offer/* // @icon  // @downloadURL https://update.greasyfork.icu/scripts/481395/1688-%E8%8E%AB%E7%9F%A5.user.js // @updateURL https://update.greasyfork.icu/scripts/481395/1688-%E8%8E%AB%E7%9F%A5.meta.js // ==/UserScript== (function () { window.setTimeout(()=>{ main() }, 5000) })(); function main(){ console.log('莫知'); var zhudivs = document.querySelectorAll('.detail-gallery-turn-wrapper'); //建立一个空数组 let imgsrclist = []; for (var i = 0; i < zhudivs.length; i++) { var div = zhudivs[i]; var img = div.querySelector('img'); //判断img是否存在 if (img) { //判断是否是视频 是视频就继续下一个图片 if (!img.classList.contains('video-icon')) { // 提取 img 标签的 src 属性 var src = img.getAttribute('src'); // console.log('图片网址:', src); imgsrclist.push(src) } } } // console.log(imgsrclist); let xiangimgsrclist=[]; var xiangdivs = document.querySelectorAll('.content-detail div:nth-child(2) img'); // console.log(xiangdivs); if (xiangdivs.length==0) { xiangdivs = document.querySelectorAll('.content-detail p img'); } for (let i = 0; i < xiangdivs.length; i++) { var xiang=xiangdivs[i] var xiangimgsrc=xiang.getAttribute('data-lazyload-src') xiangimgsrclist.push(xiangimgsrc) } // console.log(xiangimgsrclist); // 创建按钮元素 const button = document.createElement('button'); // 设置按钮文本 button.textContent = '下载主图'; // 设置按钮样式 button.style.position = 'fixed'; button.style.bottom = '200px'; button.style.right = '40px'; button.style.padding = '10px'; button.style.backgroundColor = '#007bff'; button.style.color = '#fff'; button.style.border = 'none'; button.style.cursor = 'pointer'; button.style.width = '100px'; // 添加点击事件监听器 button.addEventListener('click', async function() { // 在控制台输出点击事件 // console.log('点击了按钮!'); // 创建一个包含下载任务的 Promise 数组 const downloadTasks = imgsrclist.map((url, index) => { window.setTimeout( async ()=>{ try { const response = await fetch(url); const blob = await response.blob(); const objectURL = URL.createObjectURL(blob); // 创建一个虚拟的下载链接 const link = document.createElement('a'); link.href = objectURL; // 设置下载属性 link.download = `主图${index + 1}.jpg`; // 将链接添加到文档中 document.body.appendChild(link); // 模拟点击链接以触发下载 link.click(); // 删除链接 document.body.removeChild(link); } catch (error) { console.error('下载出错:', error); } }, 200) }); // 执行所有下载任务 await Promise.all(downloadTasks); console.log('所有主图已下载完成!'); }); // 将按钮添加到 body 元素中 document.body.appendChild(button); // 创建按钮元素 const button1 = document.createElement('button'); // 设置按钮文本 button1.textContent = '下载详情'; // 设置按钮样式 button1.style.position = 'fixed'; button1.style.bottom = '250px'; button1.style.right = '40px'; button1.style.padding = '10px'; button1.style.backgroundColor = '#007bff'; button1.style.color = '#fff'; button1.style.border = 'none'; button1.style.cursor = 'pointer'; button1.style.width = '100px'; // 添加点击事件监听器 button1.addEventListener('click', async function() { // 在控制台输出点击事件 // console.log('点击了按钮!'); // 创建一个文件夹名称 // const folderName = 'D:/360安全浏览器下载/图片'; // 创建一个包含下载任务的 Promise 数组 const downloadTasks = xiangimgsrclist.map( (url, index) => { window.setTimeout(async ()=>{ // button.click() try { const response = await fetch(url); const blob = await response.blob(); const objectURL = URL.createObjectURL(blob); // 创建一个虚拟的下载链接 const link = document.createElement('a'); link.href = objectURL; // 设置下载属性 link.download = `详情${index + 1}.jpg`; // 将链接添加到文档中 document.body.appendChild(link); // 模拟点击链接以触发下载 link.click(); // 删除链接 document.body.removeChild(link); } catch (error) { console.error('下载出错:', error); } }, 200) }); // 执行所有下载任务 await Promise.all(downloadTasks); console.log('所有详情已下载完成!'); }); // 将按钮添加到 body 元素中 document.body.appendChild(button1); // 创建按钮元素 const button2 = document.createElement('button'); // 设置按钮文本 button2.textContent = '下载全部'; // 设置按钮样式 button2.style.position = 'fixed'; button2.style.bottom = '150px'; button2.style.right = '40px'; button2.style.padding = '10px'; button2.style.backgroundColor = '#007bff'; button2.style.color = '#fff'; button2.style.border = 'none'; button2.style.cursor = 'pointer'; button2.style.width = '100px'; // 添加点击事件监听器 button2.addEventListener('click', async function() { button1.click() window.setTimeout(()=>{ button.click() }, (xiangimgsrclist.length+3)*200) }); document.body.appendChild(button2); }