您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
抖音工具
// ==UserScript== // @name [buyi] 抖音工具 // @namespace buyi // @version 1.0.2 // @description 抖音工具 // @author buyi // @match *://*.douyin.com/* // @icon  // @grant unsafeWindow // @license MIT // ==/UserScript== (function () { 'use strict'; function main() { log.log("启动中 @buyi") // 标题后增加复制按钮 function addCopyTitleIcon() { let titleNodes = document.querySelectorAll('#video-info-wrap > div.video-info-detail.isVideoInfoOptimise > div > div.title > div > div > span > span') if (!titleNodes || titleNodes.length == 0) { log.log("未找到标题节点") return } for (let i = 0; i < titleNodes.length; i++) { let titleNode = titleNodes[i] if (!titleNode) { // log.log("未找到标题节点") continue } let titleWrapNode = titleNode.parentNode.parentNode.parentNode.parentNode // 如果已添加,则不重复添加 if (titleWrapNode.querySelector('.copy-title-icon')) { // log.log("已添加复制按钮") continue } titleWrapNode.style.position = "relative" let span1 = document.createElement("span") let span2 = document.createElement("span") let copyIcon = document.createElement("img") span1.style.position = "absolute" span1.style.right = "-30px" span1.style.bottom = "2px" span1.style.zIndex = "999999" copyIcon.className = "copy-title-icon" copyIcon.src = iconCopyBase64 copyIcon.style.width = "20px" copyIcon.style.height = "20px" copyIcon.style.marginLeft = "10px" copyIcon.style.cursor = "pointer" copyIcon.style.verticalAlign = "middle" copyIcon.onclick = function () { let title = titleNode.innerText navigator.clipboard.writeText(title) showToast("复制成功") log.log("复制成功: " + title) } // 判断展开按钮是否显示 // let zhankaiIsShow = titleWrapNode.querySelector('button').parentNode.style.display != "" span2.appendChild(copyIcon) span1.appendChild(span2) titleWrapNode.appendChild(span1) } } setInterval(() => { addCopyTitleIcon() }, 1000); } // ========================================== main函数结束 ========================================== const iconCopyBase64 = '' const tool = { print(level, msg, ...args) { const now = new Date() const year = now.getFullYear() const month = (now.getMonth() + 1 < 10 ? "0" : "") + (now.getMonth() + 1) const day = (now.getDate() < 10 ? "0" : "") + now.getDate() const hour = (now.getHours() < 10 ? "0" : "") + now.getHours() const minute = (now.getMinutes() < 10 ? "0" : "") + now.getMinutes() const second = (now.getSeconds() < 10 ? "0" : "") + now.getSeconds() const timenow = "[" + year + "-" + month + "-" + day + " " + hour + ":" + minute + ":" + second + "]" const host = location.host console[level](`[🚀 ~ 抖音工具 ${host} 🎉]` + timenow + " > ", msg, ...args) } } const log = { log(msg, ...args) { tool.print("log", msg, ...args) }, info(msg, ...args) { tool.print("info", msg, ...args) }, warn(msg, ...args) { tool.print("warn", msg, ...args) }, error(msg, ...args) { tool.print("error", msg, ...args) }, debug(msg, ...args) { tool.print("debug", msg, ...args) } } // ===================================================== log end =============================================== // ========================= toast ============================= function showToast(msg) { const toast = document.createElement("div") const style = document.createElement("style") style.textContent = ` .byjs-toast { position: fixed; top: 10px; left: 10px; padding: 10px; background-color: rgba(0, 0, 0, 0.5); color: white; font-size: 16px; z-index: 9999; } ` toast.className = "byjs-toast" toast.innerHTML = msg toast.appendChild(style) document.body.appendChild(toast) setTimeout(() => { document.body.removeChild(toast) }, 3000) } // ========================= toast end ============================= // if (!unsafeWindow.$ || !unsafeWindow.jQuery || !unsafeWindow.jQuery.fn.jquery) { // log.log("获取不到$,网站匹配失败 @buyi") // return // } // 域名匹配 if (['lf-zt.douyin.com'].includes(location.host)) { log.log(`非工作目标域名: ${location.host}`) return } main() })();