コードブロックのハイライトをコピーして表示できる js プラグイン highlight.js + clipboard.js 統合

コードブロックのハイライトをコピーして表示できる js プラグイン highlight.js + clipboard.js 統合

主に2つの側面から:

1. ハイライト/改行

2. コードのコピーボタン

これら両方には既製のプラグインがあります。

コードハイライトプラグイン - highlight.js

1. ハイライト js ファイルをダウンロードします。

https://highlightjs.org/

バージョン取得ボタンをクリックして言語選択に入ります

よく使われる言語を確認してください。通常は一般的な言語で十分です。

「ダウンロード」をクリックし、ダウンロードして解凍すると、js ファイルと css ファイルが作成されます。

jsファイルはどの部分をハイライトするかを決定し、cssはコードの色を決定します。

2. 解凍したファイルから highlight.pack.js ファイルを見つけ、使用時にこの js ファイルをインポートします。

<script src="js/jquery-3.1.1.js"></script> 
<script src="js/highlight.pack.js"></script>

3. 多くの CSS ファイルが含まれるスタイル ファイルを開きます。これらのファイルを使用すると、ハイライト色や背景色 (テーマ色) など、表示コードの CSS スタイルを変更できます。

そのスタイルを使用する場合は、そのスタイルの CSS ファイルをインポートするだけで済みます。これらの英語の単語が何を表しているか分かりません。この URL は各 CSS ファイルの効果を示しています: https://highlightjs.org/static/demo/

ここでは dark.css ファイルを選択しました。

<link rel="スタイルシート" type="text/css" href="css/dark.css" rel="外部 nofollow" />

jsファイルとcssファイルをインポートしたら使用可能になります。

使用する際は、表示したいコードを必ず <pre><code></code></pre> タグで囲んでください。 ! !

コードにタグが含まれている場合は、タグの「<」を「&lt」に、「>」を「&gt」に置き換えることを忘れないでください。

コピープラグイン - clipboard.js

最初は、execCommand を直接使用してコピーを実現したいと考えました。コードは次のとおりです。コピーされたコンテンツには、改行やスペースなどの関連フォーマットがなく、互換性の問題があります。多数のプラグインを検索する過程で、既製のコピープラグインclipboard.jsが使用され、より便利かつ迅速に機能を実現できます。

<script type="text/javascript">
関数コピーリンク(){
var e = document.getElementById("コピー");
e.select(); // オブジェクトを選択 document.execCommand("Copy"); // ブラウザのコピー コマンドを実行 alert("リンクのコピーに成功しました!");
}
</スクリプト>

clipboard.js は、ブラウザからシステム クリップボードにテキストをコピーする機能を純粋な JS で実現できます。

使用中、フロントエンドブラウザにクリップボードが定義されていないというメッセージが表示されます。

最初は未定義かソースコードのエラーかと思いましたが、長い間検索した結果、jsファイルを導入する際のパスにエラーがあったことがわかりました(今後プラグインを使用する際に未定義の問題が発生した場合は、必ずF12を使用してデバッグし、404エラーがないか確認してください)

1. clipboard.jsをダウンロードします。 clipboard.js ダウンロードアドレス: https://github.com/zenorocha/clipboard.js

2. プラグインを導入する

ダウンロードしたファイルclipboard.js-master\clipboard.js-master\demoにサンプルがあり、直接使用できます。

以下は、id=copyCode の div を使用する例です。

1) jsファイルをインポートする

<script src="${ctx }/styles/js/clipboard.min.js" type="text/javascript" ></script>

2) クリップボードオブジェクトをインスタンス化する

<スクリプト>
var クリップボード = 新しい ClipboardJS('.btn');
clipboard.on('成功', 関数(e) {
   コンソールログ(e);
});
clipboard.on('エラー', 関数(e) {
コンソールログ(e);
});
</スクリプト>

3) コピー ボタンとコンテンツを定義します (注: ここでは、コピー時間をトリガーするボタンに 2 つの属性 (data-clipboard-action と data-clipboard-target) を追加する必要があります。data-clipboard-target の属性値は、ターゲット テキストの ID 値です)

<div id="copyCode">こんにちは</div>
<button class="btn" data-clipboard-action="copy" data-clipboard-target="#copyCode">コピー</button>

data-clipboard-target の値はタグにすることもできますが、タグが複数ある場合は失敗しますので、ご注意ください。

2 つのプラグインを使用する場合、競合は発生せず、適切に統合できます。

以下もご興味があるかもしれません:
  • Highlight.js JSライブラリの使い方の詳細な説明
  • jsはhighlight.jsを使用してコードを強調表示します
  • JavaScript 構文強調プラグイン highlight.js の詳細な使用方法 [highlight.js サイトのダウンロードに添付]
  • highlight.jsコードハイライトプラグインの使い方の詳しい説明

<<:  CentOS 7.5 に Python 3.6.6 を最初からインストールするための詳細なチュートリアル

>>:  MySQL 接続数を設定する方法 (接続数が多すぎる)

推薦する

jsを使用して中国語からピンインへの変換の完全な手順を実行します

jsを使用して、中国語をピンインに変換するパッケージを作成しました。倉庫のアドレスはpinyin-p...

JavaScript の setTimeout と setTimeinterval の使用例の説明

どちらの方法も、一定時間後に JavaScript コードを実行するために使用できますが、それぞれに...

VirtualBoxにOpenSuseをインストールする方法

仮想マシンはホストマシンにインストールされます。 CPU とメモリはホスト マシンと共有する必要があ...

Vue の v-model ディレクティブと .sync 修飾子の違いの詳細な説明

目次vモデル.sync微妙な違い機能シナリオを要約します。 vモデル <!--親コンポーネント...

CSS3 ボタン境界アニメーションの実装

まず効果を見てみましょう: html <a href="#"> &l...

JavaScript オブジェクトを作成する 3 つの方法

目次1. オブジェクトリテラル2. newキーワードはオブジェクトを作成する3. Object.cr...

Linux の高並列性とパフォーマンス最適化の落とし穴の紹介

目次序文Linux アプリケーション実行中に開いているファイルが多すぎる問題の分析と解決Linux ...

JS ES の新機能、変数分離割り当て

目次1. 配列の分離割り当て1.1 配列分離割り当てとは何ですか? 1.2 配列分離割り当てに失敗し...

Centos7 に MySQL 8.0.23 をインストールする手順 (初心者レベル)

まず、MySQL とは何かを簡単に紹介します。簡単に言えば、データベースはデータを格納するための倉庫...

Linux の一般的なテキスト処理コマンドと vim テキストエディタ

今日は、いくつかの一般的なテキスト処理コマンドとvimテキストエディタを紹介します。 3日目 - 一...

シンプルな虫眼鏡効果を実現するJavaScript

大きな箱の中に写真があります。マウスをその上に置くと、半透明のマスク レイヤーが表示されます。マウス...

MySQL の選択、挿入、更新バッチ操作ステートメントのコード例

プロジェクトでは、データを操作するためにバッチ操作ステートメントが必要になることがよくあります。バッ...

Navicat Premiumを使用してMySQLデータベースにリモート接続する方法

新しい接続を作成する側がクライアントに相当し、接続される側がサーバーに相当します。手順は次のとおりで...

el-table カプセル化に基づくドラッグ可能な行と列、および選択列コンポーネントの実装

効果環境が必要ビュー要素UIドラッグアンドドロッププラグインSortable.js必要な構成プロパテ...

Linux ダイナミックライブラリの生成と使用ガイドの詳細な説明

Linux での動的ライブラリ ファイルのファイル名は libxxx.so のようになります。ここで...