1688|阿里巴巴-图片批量采集

获取1688的主图和详情图片

// ==UserScript==
// @name         1688|阿里巴巴-图片批量采集
// @version      1.0
// @namespace    http://tampermonkey.net/
// @description  获取1688的主图和详情图片
// @author       无言
// @license MIT
// @match        https://detail.1688.com/offer/*
// @icon         
// @require https://cdnjs.cloudflare.com/ajax/libs/jszip/3.7.1/jszip.min.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 = '100px';
    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.style.zIndex = '10001';


    // 添加点击事件监听器
    button.addEventListener('click', async function() {
        // 在控制台输出点击事件
        // console.log('点击了按钮!');


        const zip = new JSZip();
        const imgFolder = zip.folder("images1");
    
        for (let i = 0; i < imgsrclist.length; i++) {
            const url = imgsrclist[i];
            try {
                const response = await fetch(url);
                const blob = await response.blob();
                const arrayBuffer = await blob.arrayBuffer();
                imgFolder.file(`主图${i + 1}.jpg`, arrayBuffer);
            } catch (error) {
                console.error('下载出错:', error);
            }
        }
    
        zip.generateAsync({ type: "blob" }).then((content) => {
            const objectURL = URL.createObjectURL(content);
            const link = document.createElement('a');
            link.href = objectURL;
            link.download = `主图.zip`;
            document.body.appendChild(link);
            link.click();
            document.body.removeChild(link);
        });
            
        console.log('所有主图已下载完成!');
    });

    // 将按钮添加到 body 元素中
    document.body.appendChild(button);








     // 创建按钮元素
     const button1 = document.createElement('button');

     // 设置按钮文本
     button1.textContent = '下载详情';

     // 设置按钮样式
     button1.style.position = 'fixed';
     button1.style.bottom = '50px';
     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.style.zIndex = '10001';



     // 添加点击事件监听器
     button1.addEventListener('click', async function() {
         // 在控制台输出点击事件
        //  console.log('点击了按钮!');

        const zip = new JSZip();
        const imgFolder = zip.folder("images2");
    
        for (let i = 0; i < xiangimgsrclist.length; i++) {
            const url = xiangimgsrclist[i];
            try {
                const response = await fetch(url);
                const blob = await response.blob();
                const arrayBuffer = await blob.arrayBuffer();
                imgFolder.file(`详情${i + 1}.jpg`, arrayBuffer);
            } catch (error) {
                console.error('下载出错:', error);
            }
        }
    
        zip.generateAsync({ type: "blob" }).then((content) => {
            const objectURL = URL.createObjectURL(content);
            const link = document.createElement('a');
            link.href = objectURL;
            link.download = `详情.zip`;
            document.body.appendChild(link);
            link.click();
            document.body.removeChild(link);
        });
        
         console.log('所有详情已下载完成!');
     });

     // 将按钮添加到 body 元素中
    document.body.appendChild(button1);



    // 创建按钮元素
    const button2 = document.createElement('button');

     // 设置按钮文本
    button2.textContent = '下载全部';

    // 设置按钮样式
    button2.style.position = 'fixed';
    button2.style.bottom = '5px';
    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.style.zIndex = '10001';

     // 添加点击事件监听器
    button2.addEventListener('click', async function() {
        button1.click();
        button.click();
    });
    document.body.appendChild(button2);
}