42
24

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

コードブロックにCSSだけで行番号を表示する

Last updated at Posted at 2021-10-14

下図のようにコードブロックにCSSで行番号を表示する方法を紹介します。

CleanShot 2021-10-14 at 13.52.43@2x.png

前提

CSSで行番号を表示するにあたって、コードブロックのHTMLは行が<span>などの要素で表現されている必要があります。

CleanShot 2021-10-14 at 13.51.51@2x.png

行番号を表示するCSS

行番号を表示するCSSは次のようになります。

.code {
  counter-reset: line-number;
}

.code span {
  counter-increment: line-number;
  display: list-item;
  padding-left: 1rem;
  margin-left: 1rem;
}

.code span::marker {
  content: counter(line-number);
  color: #aaa;
}

それぞれ重要な箇所を説明します。

まず、.code spanを見てみましょう。

.code span {
  /* ... */
  display: list-item;
  /* ... */
}

このdisplay: list-itemは行要素の<span><li>相当にするものです。これにより、行はリストタグになり「・」のようなマーカーが表示されます。

リスト要素のマーカーのスタイルは疑似セレクター::markerで設定できます。リストマーカーのスタイルを指定するのが次のCSSです。

.code span::marker {
  content: counter(line-number);
  color: #aaa;
}

このcontent: counter(line-number)で、リストマーカーを「・」ではなく数字にしています。

デモ

実際の表示のされかたはCodePenのデモを御覧ください。

See the Pen 行番号を表示するCSS by suin (@suin) on CodePen.

42
24
2

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
42
24

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?