Greasy Fork

Greasy Fork is available in English.

下载抖音商城商品图片

使用步骤:打开抖音,进入抖音商城,随便选择一款商品点击分享,然后打开商品链接,此时浏览器可视窗口中会出现两个按钮分别为“下载全部轮播图”、“下载全部详情图”

当前为 2023-06-02 提交的版本,查看 最新版本

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Greasemonkey 油猴子Violentmonkey 暴力猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Violentmonkey 暴力猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Userscripts ,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展后才能安装此脚本。

(我已经安装了用户脚本管理器,让我安装!)

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

(我已经安装了用户样式管理器,让我安装!)

// ==UserScript==
// @name         下载抖音商城商品图片
// @namespace    http://tampermonkey.net/
// @version      0.1
// @description  使用步骤:打开抖音,进入抖音商城,随便选择一款商品点击分享,然后打开商品链接,此时浏览器可视窗口中会出现两个按钮分别为“下载全部轮播图”、“下载全部详情图”
// @author       Aman
// @match       *://haohuo.jinritemai.com/*
// @icon        
// @license     GPL
// @grant       GM_xmlhttpRequest
// @grant       GM_download
// @grant       GM_addStyle
// ==/UserScript==

(function() {
    'use strict'

    const timer = setInterval(() => {
        try {
            if (isItLoaded()) {
                clearInterval(timer)
                // start...
                createButtonDownloadArea()
                createCarouselDownloadButton()
                createDetailDownloadButton()
                // style
                applyStyle()
            }
        } catch (ignore) {
            // ignore...
        }
    }, 200)

    /**
     * 轮播图和详情图是否已经加载完毕
     * @returns {boolean}
     */
    const isItLoaded = () => {
        const parents = document.querySelector('#container > div.head-figure.default_container > div.head-figure__media-view > div > div').children
        const detailImageUrls = document.querySelectorAll('#container > div.detail-container__components > div.detail-container__sold-content > div.partial-detail-wrapper > div.product-big-img-list img')
        return parents !== undefined && detailImageUrls !== undefined
    }

    /**
     * 创建一个区域,用于存放下载按钮
     */
    const createButtonDownloadArea = () => {
        const buttonDownloadArea = document.createElement('div')
        buttonDownloadArea.id = 'buttonDownloadArea'
        document.documentElement.appendChild(buttonDownloadArea)
    }

    /**
     * 创建轮播图下载按钮
     */
    const createCarouselDownloadButton = () => {
        const downloadButton = document.createElement('button')
        downloadButton.id = 'downloadCarouselImagesButton'
        downloadButton.innerText = '下载全部轮播图'
        downloadButton.onclick = () => {
            downloadCarouselImages()
        }

        const buttonDownloadArea = document.getElementById('buttonDownloadArea')
        buttonDownloadArea.appendChild(downloadButton)
    }

    /**
     * 创建详情图下载按钮
     */
    const createDetailDownloadButton = () => {
        const downloadButton = document.createElement('button')
        downloadButton.id = 'downloadDetailImagesButton'
        downloadButton.innerText = '下载全部详情图'
        downloadButton.onclick = () => {
            downloadDetailImages()
        }

        const buttonDownloadArea = document.getElementById('buttonDownloadArea')
        buttonDownloadArea.appendChild(downloadButton)
    }

    /**
     * 下载轮播图
     */
    const downloadCarouselImages = () => {
        const parents = document.querySelector('#container > div.head-figure.default_container > div.head-figure__media-view > div > div').children
        const arrayChildren = Array.from(parents).map(parent => Array.from(parent.children))
        const imgUrls = arrayChildren.map(item => item.map(i => i.style.backgroundImage))
        const urlRegex = /url\("(.+)"\)/

        imgUrls.forEach(imgUrl => {
            imgUrl.forEach(img => {
                const [, url] = img.match(urlRegex)
                setTimeout(() => {
                    downloadImage2(url, randomFilename('轮播图'))
                }, 600)
            })
        })
    }

    /**
     * 生成一个随机字符串文件名
     * @param prefix 文件名前缀
     * @returns {string}
     */
    const randomFilename = (prefix) => {
        return prefix + '-' + Math.random().toString(36).substring(2, 10)
    }

    /**
     * 下载详情图
     */
    const downloadDetailImages = () => {
        const detailImageUrls = document.querySelectorAll('#container > div.detail-container__components > div.detail-container__sold-content > div.partial-detail-wrapper > div.product-big-img-list img')

        Array.from(detailImageUrls).forEach(detailImage => {
            setTimeout(() => {
                downloadImage2(detailImage.src, randomFilename('详情图'))
            }, 600)
        })
    }

    /**
     * 点击超链接,下载
     */
    const downloadImage2 = (url, filename) => {
        console.log('准备下载文件 ==>>> ', url)
        if (filename === undefined || filename === '') {
            filename = Date.now() + '-file'
        }
        GM_download(url, filename)
    }

    const applyStyle = () => {
        GM_addStyle(
            `
    #buttonDownloadArea {
      position: fixed;
      top: 20%;
      left: 10px;
      z-index: 99999;
      text-align: center;
    }

    #downloadDetailImagesButton, #downloadCarouselImagesButton {
      background-color: #099cee; /* 设置背景颜色 */
      border: none; /* 去掉边框 */
      color: white; /* 设置文字颜色 */
      padding: 10px 20px; /* 设置内边距 */
      text-align: center; /* 文字居中 */
      text-decoration: none; /* 去掉下划线 */
      display: block; /* 设置为行内块级元素 */
      font-size: 16px; /* 设置字体大小 */
      border-radius: 5px; /* 设置圆角 */
      box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.2); /* 设置阴影 */
      cursor: pointer; /* 鼠标悬停时显示手型 */
      margin: 10px auto;
    }

    #downloadCarouselImagesButton:hover, #downloadDetailImagesButton:hover {
      background-color: #3e8e41; /* 鼠标悬停时改变背景颜色 */
    }
  `
        )
    }
})();