Stackoverflow Add Button For Copy to clipboard

Stackoverflow Add Button For Copy to clipboard.

目前为 2022-01-05 提交的版本。查看 最新版本

// ==UserScript==

// @namespace    https://openuserjs.org/users/a29527806
// @name         Stackoverflow Add Button For Copy to clipboard
// @description  Stackoverflow Add Button For Copy to clipboard.
// @copyright    2022, HrJasn (https://openuserjs.org/users/a29527806)
// @license      GPL-3.0-or-later
// @version      1.2
// @icon         https://www.google.com/s2/favicons?domain=stackoverflow.com
// @include      https://stackoverflow.com/questions/*
// @grant        none
// ==/UserScript==

// ==OpenUserJS==
// @author       a29527806
// ==/OpenUserJS==

window.onload = function() {

    const precodeObjs = document.querySelectorAll('pre code');
    
    const scrollbarChange = function(){
        let copyBtn = this.querySelector('input[value="Copy"]');
        copyBtn.style.right = (5-this.scrollLeft) + 'px';
        copyBtn.style.bottom = (5-this.scrollTop) + 'px';
    }

    precodeObjs.forEach(function(precodeObj){
        let copyBtn = document.createElement('input');
        copyBtn.type='button';
        copyBtn.value='Copy';
        copyBtn.style='cursor:pointer;opacity:0;position:absolute;right:5px;bottom:5px;font-size:15px;padding:10px;background-color:#888888;border:0px;border-style:solid;color: #ffffff;text-shadow: 0px 0px 2px #ffffff;border-radius:5px;';
        precodeObj.parentNode.style.position = 'relative';
        precodeObj.parentNode.appendChild(copyBtn);
        precodeObj.parentNode.addEventListener("wheel",scrollbarChange,false);
        precodeObj.parentNode.addEventListener("scroll",scrollbarChange,false);
        precodeObj.parentNode.addEventListener("keydown",scrollbarChange,false);
        copyBtn.addEventListener('click', function(){
            let targetObj = this.parentNode;
            let srcText = targetObj.textContent || targetObj.innerText || targetObj.nodeValue || '';
            navigator.clipboard.writeText(srcText);
            //let clipText = navigator.clipboard.readText();
            console.log(srcText);
            if(srcText !== undefined){
                this.value='Copied';
            }
        });
        copyBtn.addEventListener('mouseenter', function(){
            this.style.opacity = 1;
        });
        copyBtn.addEventListener('mouseleave', function(){
            this.style.opacity = 0;
        });
    });

}

QingJ © 2025

镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址