olタグで括弧付きの数字で表示する

 

 Web技術

原稿をいただいた時にその中のリストの数字が括弧付きになっており
「olタグを使いたいけど原稿のデザイン通り括弧付きにはしたい…う~む…」
ということが結構ありました。

今回はその悩みを解決する方法です。

通常のタグ

↓「list-style-position:outside;」のための調整

DEMO

  1. あいうえお
  2. かきくけこ
  3. さしすせそ
  4. たちつてと
  5. なにぬねの
  6. はひふへほ
  7. まみむめも
  8. やゆよ
  9. らりるれろ
  10. わをん

「(1)」と括弧付き数字で表示したい時

「list-style-type: none;」で初期のリスト表示を非表示にして
「counter-increment」でカウンターの値に1を加算。
擬似要素の「content」でカウンターの値を括弧で挟んで表示させます。

DEMO

  1. あいうえお
  2. かきくけこ
  3. さしすせそ
  4. たちつてと
  5. なにぬねの
  6. はひふへほ
  7. まみむめも
  8. やゆよ
  9. らりるれろ
  10. わをん

 

括弧付き数字になりました。

 

ですが

 

「list-style-position:inside;」を指定したような表示になってしまい、
二行になると文章の頭がズレてしまします。

また番号が右揃えではないため二桁番号になった時
リスト内の文章がズレて見えます。

調整する①

olタグに「margin-left」、liタグに「display:inline-block;」、
li::beforeに「margin-left」と「width」を指定して調整します。

DEMO

  1. あいうえお
    あいうえお
  2. かきくけこ
  3. さしすせそ
  4. たちつてと
  5. なにぬねの
  6. はひふへほ
  7. まみむめも
  8. やゆよ
  9. らりるれろ
  10. わをん

 

「list-style-position:outside;」を指定したような表示になりました。
二行になっても文章の頭が揃います。

 

ですが

 

右揃え指定(li::beforeに「text-align:right;」)をすると
括弧と文章の間がくっついて見えます。

ここを調整したいと思いました。

調整する②

liタグに「position:relative;」、li::beforeに「position:absolute;」と
「top:0;」「left:0;」を指定することで調整ができるようになりました。

DEMO

  1. あいうえお
    あいうえお
  2. かきくけこ
  3. さしすせそ
  4. たちつてと
  5. なにぬねの
  6. はひふへほ
  7. まみむめも
  8. やゆよ
  9. らりるれろ
  10. わをん

▼参考にさせていただきました。ありがとうございました。

 この記事の投稿者

taka

taka

Webサイト作ってます。
最近のモットー「決して無理をしないスタイル」

twitter: @taka_sbs

  • このエントリーをはてなブックマークに追加
  • 0 follow us in feedly

メッセージ

入力エリアすべてが必須項目です。
メールアドレスが公開されることはありません。

*コメント

*名前

ページ最上部へ