😊

Tailwind CSS マーカーとテキストの重なりを防ぐ方法

2024/10/06に公開

Reactを使ってリストを表示する際、ulタグのリストアイテムが長くなった場合、次の行のテキストがリストのマーカー(点や番号)と重なってしまうことがあります。
ここでは解決案の一例を解説します。

問題の概要

以下のようにリストを生成するコードがあります。

<ul className='list-disc list-inside'>
  {liveNames.map((liveName) => (
    <li key={liveName.id} className='py-2 marker:text-primary'>
      {liveName.name}
    </li>
  ))}
</ul>

list-insideによって、マーカーをリストアイテムの内側に配置します。
これにより、リストアイテムが複数行に渡った際、改行されたテキストがマーカーと重なりやすくなってしまいます。

モバイル表示でリストアイテムが複数行に渡ると、2行目以降のテキストがマーカーと重なっています。

解決案

<ul className='list-disc list-outside ml-6'>
  {liveNames.map((liveName) => (
    <li key={liveName.id} className='py-2 marker:text-primary'>
      {liveName.name}
    </li>
  ))}
</ul>

リストマーカーを外側に配置する

list-outsideを使って、マーカーをテキストの外側に配置します。
マーカーとテキストが明確に分離されるため、基本的なレイアウト問題を解消します。

適切なマージンを設定する

ml-6でリストアイテムの左にマージンを設定して、マーカーとテキストとの間に十分なスペースを確保します。これにより、マーカーとテキストが重ならないようにします。


マーカーとテキストが重ならないようになる

list-outsideを使う場合はマーカーがテキストの外側に配置されてしまうため、マージンの設定は必須です。


ml-6を記載しなかった場合。裏の茶色はDevToolsの背景色

以上です。

Discussion