您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
按 Alt+C 或点击标题复制 Markdown 链接格式的视频地址和标题,自动弹出提示信息。
// ==UserScript== // @name B站视频 Markdown 链接复制(Alt+C + 点击标题) // @namespace http://tampermonkey.net/ // @version 0.2 // @description 按 Alt+C 或点击标题复制 Markdown 链接格式的视频地址和标题,自动弹出提示信息。 // @author diudiu // @match https://www.bilibili.com/video/* // @grant none // @license MIT // ==/UserScript== (function () { 'use strict'; function getMarkdownLink() { const titleElement = document.querySelector("#viewbox_report > div.video-info-title > div > h1"); if (!titleElement) { alert("未找到标题元素!"); return null; } const title = titleElement.innerText.trim(); const url = window.location.href.split('?')[0]; // 去除参数部分 return `[${title}](${url})`; } function showCopiedMessage(msg) { const div = document.createElement("div"); div.textContent = msg; div.style.position = "fixed"; div.style.top = "20px"; div.style.right = "20px"; div.style.padding = "10px 15px"; div.style.background = "#00AEEC"; div.style.color = "white"; div.style.zIndex = 99999; div.style.borderRadius = "8px"; div.style.fontSize = "16px"; div.style.boxShadow = "0 0 8px rgba(0,0,0,0.3)"; document.body.appendChild(div); setTimeout(() => div.remove(), 2000); } function copyMarkdown() { const md = getMarkdownLink(); if (md) { navigator.clipboard.writeText(md).then(() => { showCopiedMessage("✅ 已复制 Markdown 链接"); }).catch(err => { showCopiedMessage("❌ 复制失败:" + err); }); } } // 快捷键监听:Alt + C document.addEventListener("keydown", function (e) { if (e.altKey && e.code === "KeyC") { copyMarkdown(); } }); // 添加点击标题复制功能 function addClickListenerToTitle() { const titleElement = document.querySelector("#viewbox_report > div.video-info-title > div > h1"); if (titleElement) { titleElement.style.cursor = "pointer"; titleElement.title = "点击复制 Markdown 链接"; titleElement.addEventListener("click", copyMarkdown); } } // 页面加载完成后添加监听 window.addEventListener("load", () => { setTimeout(addClickListenerToTitle, 1000); // 延迟一点以确保元素加载 }); })();