亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

為網(wǎng)站代碼塊pre標(biāo)簽增加一個(gè)復(fù)制代碼按鈕代碼

 更新時(shí)間:2021年11月20日 16:59:02   作者:李清燦  
寫文章的時(shí)候,作為一名專業(yè)的碼農(nóng),經(jīng)常會在文章中粘貼一些代碼。有的時(shí)候代碼塊比較長,在后期使用中需要復(fù)制這段代碼就比較麻煩

參考其他比較專業(yè)的博客系統(tǒng),都在代碼塊上有一個(gè)復(fù)制代碼的按鈕。用來快速復(fù)制整個(gè)代碼塊的代碼。于是我也想給我的博客增加一個(gè)這個(gè)功能。

注:chrome測試通過。其他瀏覽器未進(jìn)行測試。

實(shí)現(xiàn)思路:

1、在頁面加載完成之后,使用js給每個(gè)pre標(biāo)簽增加一個(gè)按鈕“復(fù)制代碼”

2、給按鈕增加點(diǎn)擊事件,點(diǎn)擊事件的功能就是復(fù)制代碼塊的內(nèi)容

實(shí)現(xiàn)代碼:

css部分,btn-pre-copy是pre標(biāo)簽中使用js增加的“復(fù)制代碼”按鈕。css的作用是讓他顯示在pre標(biāo)簽的右上角。這里要注意pre標(biāo)簽和按鈕中position屬性

.content pre{
    position: relative;
    background-color: #f5f5f5;
    border: 1px solid #ccc;
    border-radius: 4px;
    padding: 10px;
}
pre .btn-pre-copy{
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    -khtml-user-select: none;
    user-select: none;
    position: absolute;
    top: 10px;
    right: 12px;
    font-size: 12px;
    line-height: 1;
    cursor: pointer;
    color: hsla(0,0%,54.9%,.8);
    transition: color .1s;
}

js部分,js部分主要是給pre標(biāo)簽增加按鈕和實(shí)現(xiàn)拷貝部分,我這里拷貝部分的實(shí)現(xiàn)是先實(shí)例化一個(gè)臨時(shí)的節(jié)點(diǎn)textarea,然后吧pre的內(nèi)容設(shè)置進(jìn)這個(gè)臨時(shí)節(jié)點(diǎn),然后選中內(nèi)容進(jìn)行復(fù)制,最后銷毀這個(gè)節(jié)點(diǎn)。具體參考代碼。js部分有依賴于jquery

$(function(){
    //給每一串代碼元素增加復(fù)制代碼節(jié)點(diǎn)
    let preList = $(".content pre");
    for (let pre of preList) {
        //給每個(gè)代碼塊增加上“復(fù)制代碼”按鈕
        let btn = $("<span class=\"btn-pre-copy\" onclick='preCopy(this)'>復(fù)制代碼</span>");
        btn.prependTo(pre);
    }
});

/**
    * 執(zhí)行復(fù)制代碼操作
    * @param obj
    */
function preCopy(obj) {
    //執(zhí)行復(fù)制
    let btn = $(obj);
    let pre = btn.parent();
    //為了實(shí)現(xiàn)復(fù)制功能。新增一個(gè)臨時(shí)的textarea節(jié)點(diǎn)。使用他來復(fù)制內(nèi)容
    let temp = $("<textarea></textarea>");
    //避免復(fù)制內(nèi)容時(shí)把按鈕文字也復(fù)制進(jìn)去。先臨時(shí)置空
    btn.text("");
    temp.text(pre.text());
    temp.appendTo(pre);
    temp.select();
    document.execCommand("Copy");
    temp.remove();
    //修改按鈕名
    btn.text("復(fù)制成功");
    //一定時(shí)間后吧按鈕名改回來
    setTimeout(()=> {
        btn.text("復(fù)制代碼");
    },1500);
}

這里在gitee上做了一個(gè)簡單的demo。demo示例:

在線測試:http://demo.jb51.net/js/2021/code_copy/

到此這篇關(guān)于為網(wǎng)站代碼塊pre標(biāo)簽增加一個(gè)復(fù)制代碼按鈕代碼的文章就介紹到這了,更多相關(guān)代碼高亮增加復(fù)制代碼功能內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 微信小程序?qū)崿F(xiàn)購物頁面左右聯(lián)動

    微信小程序?qū)崿F(xiàn)購物頁面左右聯(lián)動

    這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)購物頁面左右聯(lián)動,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-02-02
  • Electron點(diǎn)擊穿透不規(guī)則窗體的透明區(qū)域的實(shí)現(xiàn)

    Electron點(diǎn)擊穿透不規(guī)則窗體的透明區(qū)域的實(shí)現(xiàn)

    本文主要介紹了Electron點(diǎn)擊穿透不規(guī)則窗體的透明區(qū)域的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • TypeScript中遍歷對象鍵的方法

    TypeScript中遍歷對象鍵的方法

    在日常的TypeScript開發(fā)中,經(jīng)常需要遍歷對象的鍵來執(zhí)行各種操作,,在本文中,我們將深入研究這個(gè)問題,并提供幾種解決方案,以便在遍歷對象鍵時(shí)更安全、更靈活地操作,文中有詳細(xì)的代碼講解,需要的朋友可以參考下
    2023-11-11
  • 實(shí)例講解JS中setTimeout()的用法

    實(shí)例講解JS中setTimeout()的用法

    這篇文章主要介紹了JS中setTimeout()的用法,setTimeout()是屬于window的method,但我們都是略去window這頂層對象名稱,這是用來設(shè)定一個(gè)時(shí)間,時(shí)間到了,就會執(zhí)行一個(gè)指定的method,需要深入了解的朋友可以參考下
    2016-01-01
  • js實(shí)現(xiàn)圖片淡入淡出切換簡易效果

    js實(shí)現(xiàn)圖片淡入淡出切換簡易效果

    這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)圖片淡入淡出切換簡易效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-08-08
  • JavaScript style對象與CurrentStyle對象案例詳解

    JavaScript style對象與CurrentStyle對象案例詳解

    這篇文章主要介紹了JavaScript style對象與CurrentStyle對象案例詳解,本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • JS判斷鼠標(biāo)進(jìn)入容器的方向與window.open新窗口被攔截的問題

    JS判斷鼠標(biāo)進(jìn)入容器的方向與window.open新窗口被攔截的問題

    這篇文章主要給大家介紹了利用Javascript判斷鼠標(biāo)進(jìn)入容器方向的方法,以及window.open新窗口被攔截的問題分析,文中給出了詳細(xì)圖文介紹和示例代碼,相信對大家的理解和學(xué)習(xí)具有一定的參考借鑒價(jià)值,下面來一起看看吧。
    2016-12-12
  • Javascript實(shí)現(xiàn)簡單的富文本編輯器附演示

    Javascript實(shí)現(xiàn)簡單的富文本編輯器附演示

    這篇文章主要介紹了通過Javascript實(shí)現(xiàn)的簡單富文本編輯器,需要的朋友可以參考下
    2014-06-06
  • 合并多個(gè)ArrayBuffer場景及方法示例

    合并多個(gè)ArrayBuffer場景及方法示例

    這篇文章主要為大家介紹了合并多個(gè)ArrayBuffer方法示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-11-11
  • js如何判斷不同系統(tǒng)的瀏覽器類型

    js如何判斷不同系統(tǒng)的瀏覽器類型

    正如標(biāo)題所言使用js如何判斷不同系統(tǒng)的瀏覽器類型,下面有個(gè)不錯(cuò)的示例,感興趣的朋友可以參考下
    2013-10-10

最新評論