在網站copy時自帶的版權小尾巴以及“複製代碼“,可以怎麼實現

来源:https://www.cnblogs.com/rainy-night/archive/2022/04/11/16132466.html
-Advertisement-
Play Games

前言 每天網上的博客各個領域都會涌現新文章,有時候看到感興趣的知識就想把某段文字 copy下來 摘錄下來,等有時間後慢慢品味 在部分網站上,如果只是複製少量文字,並沒有什麼不同。但是當我們複製的文字多的話會發現多了一個小尾巴 所謂小尾巴是指在複製文本的最後會多一個作者和出處信息,如下: ···(複製 ...


前言

每天網上的博客各個領域都會涌現新文章,有時候看到感興趣的知識就想把某段文字 copy下來 摘錄下來,等有時間後慢慢品味

在部分網站上,如果只是複製少量文字,並沒有什麼不同。但是當我們複製的文字多的話會發現多了一個小尾巴

所謂小尾巴是指在複製文本的最後會多一個作者和出處信息,如下:

···(複製的內容)···
————————————————
版權聲明:本文為xxx的原創文章,遵循CC 4.0 BY-SA版權協議,轉載請附上原文出處鏈接及本聲明。
原文鏈接:https://www.cnblogs.com/rainy-night/

博客園可能並沒有這種情況,但是在很多技術論壇、博客都有這樣的處理。當我們複製文章內容的時候,往往會自動加上一段文本信息版權

那麼如果我們也想實現這樣的效果要怎麼做呢?

實現

版權小尾巴

前提:假定所選擇的字元串長度大於等於130時帶上版權信息

<div id="copy">
  <div>示例一:這不是一個 bug,這隻是一個未列出來的特性。</div>
  <div>
    示例二:ES6 是一個泛指,含義是 5.1 版以後的 JavaScript。
    ES6 是 JavaScript 語言的下一代標準,已經在 2015 年 6 月正式發佈了。
    它的目標,是使得 JavaScript 語言可以用來編寫複雜的大型應用程式,使之成為企業級開發語言。
  </div>
</div>

<script>
var copyEl = document.getElementById('copy');
copyEl.oncopy = function (e) {
  if (window.getSelection(0).toString().length >= 130) {
    var clipboardData = event.clipboardData || window.clipboardData;
    // 阻止預設事件
    e.preventDefault();
    var copyMsg =
      window.getSelection() +
      '\r\n————————————————\r\n版權聲明:本文為xxx的原創文章,遵循CC 4.0 BY-SA版權協議,轉載請附上原文出處鏈接及本聲明。' +
      '\r\n原文鏈接:' + location.href;
    // 將處理完的信息添加到剪切板
    clipboardData.setData('Text', copyMsg);
    // 將處理完的信息添加到剪切板
    clipboardData.setData('Text', copyMsg);
  }
};
</script>

演示

瀏覽器相容性

當複製示例一後可以發現粘貼是正常的;複製示例二則會在末尾攜帶版權信息

複製代碼功能

我們直接複製代碼,會發現當字數超過一定值時也是會攜帶版權信息。但是點擊“複製代碼”的時候可以一鍵複製區域內的代碼,這可以怎麼實現呢?

<div>
  <pre>
<code id="copyable">// 浮點數相加
function mathMultiply(arg1, arg2) {
  var m = 0;
  var s1 = arg1.toString();
  var s2 = arg2.toString();
  try {
    m += s1.split('.')[1].length; // 小數相乘,小數點後個數相加
  } catch (e) {}
  try {
    m += s2.split('.')[1].length;
  } catch (e) {}
  return (
    (Number(s1.replace('.', '')) * Number(s2.replace('.', ''))) /
    Math.pow(10, m)
  );
 }<code />
</pre>
  <button id="btn">複製代碼</button>
</div>

<script>
  var btn = document.getElementById('btn');
  btn.onclick = function copyCode() {
    window.getSelection().removeAllRanges(); // 清除選中的文本
    var range = document.createRange();
    range.selectNode(document.getElementById('copyable'));
    var selection = window.getSelection();
    selection.addRange(range); // 添加選中的內容
    document.execCommand('copy'); // 執行複製
    window.getSelection().removeAllRanges(); // 清除複製選中的文本
    alert('代碼複製成功');
  };
</script>

演示
在這裡插入圖片描述
瀏覽器相容性

document.execCommand()因為安全問題已經廢棄,不適合長期使用

第三方工具

除了以上實現方式,也可以使用第三方庫封裝好的函數來實現

clipboard.js


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 雲主機作為雲計算最基礎、最核心的產品,承擔了大部分企業的計算任務,其性能和穩定性直接決定了雲計算的用戶體驗。 眾所周知,雲計算從來不是科技的狂人妄語,在科技技術飛速發展的時代,在技術市場,我們目睹了這個產業從零到數千億美元,黃金白銀的背後都來自產業的真實需求。尤其是突如其來的疫情,雖然讓很多產業均受 ...
  • Linux進程通訊機制 Linux 系統中有萬物皆文件的說法,虛擬文件系統(VFS)是 Linux 對外的介面,任何程式都必須通過這層介面來使用它。 為了避免系統安全問題(越權訪問),進程間記憶體無法共用,數據交互就得採用特殊的通信機制(IPC)。 進程劃分用戶空間(不可共用)跟內核空間(可共用),並 ...
  • 前言 為什麼要老藥換新湯 作為Android中 至關重要 的機制之一,十多年來,分析它的文章不斷,大量的內容已經被挖掘過了。所以: 已經對這一機制熟稔於心的讀者,在這篇文章中,看不到新東西了。 但對於還不太熟悉消息機制的讀者,可以在文章的基礎上,繼續挖一挖。 一般,諸如此類有關Android的消息機 ...
  • 所有OpenHarmony相關官方直播課程,我們都將在OpenHarmony B站官方賬號“OpenHarmony開發者社區”上彙總發佈。 ...
  • 為了適配更多移動產品形態、提升用戶體驗、以及與合作伙伴協同促進生態建設持續高品質發展,我們本次對《原子化服務上架規範》(後文簡稱:規範)做了更新。 ...
  • 前言 在 $AppClick 事件採集中,還有兩個比較特殊的控制項: UITableView •UICollectionView 這兩個控制項的點擊事件,一般指的是點擊 UITableViewCell 和 UICollectionViewCell。而 UITableViewCell 和 UICollec ...
  • 當用戶卸載App徹底流失時,應用內消息等便捷的用戶觸達交互紐帶將無法再次連通他們,且對於卸載用戶的判定更是技術瓶頸。如何便捷且合理的通過運營策略將卸載用戶召回,是用戶運營同學迫切想知道的答案。 某知名RPG游戲對玩家的活躍度要求極高,通常會判定超過3天未登錄的用戶可能已徹底卸載。對於卸載用戶的召回, ...
  • 經過前面六天的知識學習,對Node.js開發的基礎知識,有了一個初步的掌握,今天繼續學習Node.js後端web開發的相關知識,本篇文章作為Node.js服務端程式開發的基礎入門知識,僅供學習分享使用,如有不足之處,還請指正。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...