Greasy Fork is available in English.

1688-莫知

爬图片

// ==UserScript==
// @name         1688-莫知
// @version      1.0
// @namespace    http://tampermonkey.net/
// @description  爬图片
// @author       莫知
// @license MIT
// @match        https://detail.1688.com/offer/*
// @icon         
// ==/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);
}