4
5

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 5 years have passed since last update.

css display:tableで、[非]等間隔に並べるには

Posted at

display:tableざっくり概要

cssでdisplay: table;display: table-cell;をつかってレイアウトする際にちょっとはまった事。
display:tableを使うとテーブルレイアウトできるから、縦ラインを揃えられたり、table-layout: fixed;を指定する事でセル幅を揃えることができる。

やりたいこと

table内のセルを一部に隙間を開けたい場合、ちょっとハマった。そもそもtable-cellにはmarginが効かないという事をマークアップして初めて気づいた。background-clipというプロパティを使うとできるらしいけど、今回はIE8対応しなくちゃならないのでボツ。

結果

まあ一番原始的な・・・というかこれしか思いつかなかったけど、table-cellの中にブロック要素を配置してそれをレイアウトするやり方で解決しました。table-cellを指定した要素は直接レイアウトしない。

#例えば一番左セルに隙間を空ける
.table1 li:first-child div {
	margin-right: 30px;
}
</style>
<ul class="table1">
	<li><div>A</div></li>
	<li><div>B</div></li>
	<li><div>C</div></li>
	<li><div>D</div></li>
	<li><div>E</div></li>
</ul>
4
5
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
4
5

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?