您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Adds "Open with VSCode" button
// ==UserScript== // @name Github - Open with VSCode // @namespace V@no // @description Adds "Open with VSCode" button // @match https://github.com/* // @version 24.5.9-085044 // @license MIT // @run-at document-end // @grant none // ==/UserScript== (() => { "use strict"; const fixLink = () => { const elUL = document.querySelector(`#__primerPortalRoot__ > div > div > div > ul > div > ul`); if (!elUL) return true; const elLiVStudio = elUL.querySelector(`[id]:nth-child(2)`); if (elLiVStudio && !elLiVStudio.querySelector(".icon")) { const elImg_Vstudio = document.createElement("img"); elImg_Vstudio.classList.add("mr-2", "icon"); elImg_Vstudio.src = "https://raw.githubusercontent.com/vanowm/userscript_github-open_with_vscode/master/media/vstudio.svg"; elLiVStudio.prepend(elImg_Vstudio); } const elLi_DownloadZip = elUL.querySelector(`li:last-child`); const elLi_VSCode = (elUL.querySelector(".vscode") || elLi_DownloadZip.cloneNode(true)); if (!elLi_VSCode.parentNode) { elLi_VSCode.classList.add("vscode"); const elA_VSCode = elLi_VSCode.querySelector("a"); elA_VSCode.textContent = "Open with VSCode"; const elImg_Vscode = document.createElement("img"); elImg_Vscode.classList.add("mr-2", "icon"); elImg_Vscode.src = "https://raw.githubusercontent.com/vanowm/userscript_github-open_with_vscode/master/media/vscode.svg"; elA_VSCode.prepend(elImg_Vscode); const cloneURL = (elUL.parentNode.querySelector(`input`) || {}).value || location.origin + location.pathname + ".git"; elA_VSCode.href = "vscode://vscode.git/clone?url=" + encodeURI(cloneURL); elLi_DownloadZip.parentNode.insertBefore(elLi_VSCode, elLi_DownloadZip); } }; const observer = new MutationObserver(fixLink); fixLink(); observer.observe(document, {childList: true, subtree: true}); })();