border样式在平时我们使用的频率是非常高的,但是除了表单table之外,我们几乎都是一对一的使用,一般不会遇到什么问题。

       而在table中众多的数据排列在一起,为了将各个数据隔开,我们就不得不使用boder进行操作。由于表格相对其他元素的特殊性,我们在对表单进行表格操作时,往往会遇到一些特殊的情况。

       这不最近我在做后台管理时就经常需要和table打交道,如果你不熟悉table和其内容之间的关系的话,美化起来非常麻烦,在尝试了众多样、查阅了众多资料之后,下面让我们一点一点来揭开Table的神秘面纱。

<table class="laoye-table" border="8" cellspacing="10" cellpadding="5">
	<tbody class="laoye-table-head">
		<tr>
			<th>Header</th>
			<th>Header</th>
			<th>Header</th>
		</tr>
	</tbody>
	<tbody class="laoye-tbody">
		<tr>
			<td>Data1</td>
			<td>Data1</td>
			<td>Data1</td>
		</tr>
		<tr>
			<td>Data</td>
			<td>Data</td>
			<td>Data</td>
		</tr>
	</tbody>
</table>

border表示的是表单的边框为8px;cellspacing规定了单元格与单元格、单元格和边距之间的空白距离为10px。 cellpadding规定了内容和单元格之间的空白距离是5px

                      

element table列样式_element table列样式

       那么问题来了,如果我只想要保留一个像素的边框该怎么做呢?boder改为1?单元格和单元格之间的距离改为0?

                                                 

element table列样式_td_02

       嗯,看实结果是达到了,但是怎么感觉有点粗呢?我们不妨测试一下,检验一下。

       我们设置tr的所有子元素为红色边框,即border-color:red;然后设置单元格与边框之间的内容空白为1(如果我们不设置默认为1)

                                                 

element table列样式_Table_03

       结果可以看出,单元格和单元格、单元格和边框都重合在了一起,也就是说,当我们把表格边框的宽度改为1,表单的单元格改为1时,单元格和边框、单元格和单元格都互相重合在一起,成为了一个2px的边框。

通过CSS设置表格table的样式。

//HTML语句
<table class="laoye-table" border="1" cellspacing="10" cellpadding="20">
	<tbody class="laoye-table-head">
		<tr>
			<th>Header</th>
			<th>Header</th>
			<th>Header</th>
		</tr>
	</tbody>
	<tbody class="laoye-tbody">
		<tr>
			<td>Data1</td>
			<td>Data1</td>
			<td>Data1</td>
		</tr>
		<tr>
			<td>Data</td>
			<td>Data</td>
			<td>Data</td>
		</tr>
	</tbody>
</table>
//CSS语句
.laoye-table{
	border-collapse:collapse;
}

结果图:

element table列样式_element table列样式_04

 

       加上这条语句之后,我们可以看到,表格边框宽度和单元格之间的宽度变小了。那么这条语句到底是干什么的呢?

       border-collapse

element table列样式_td_05

       所以当我们将border-collapse设置为collapse之后直接忽略了单元格和单元格之间的距离,另外需要注意的是,我们肉眼看起来表单的外边框和单元格的外边框重合在了一起,但是这个重合后的宽度是更具彼此之间的宽度来定的。比如一个厚2px和4px的边框重合,那么它的厚度就是4px。

       当我们解决了上诉的问题之后,我们就可以对表单进行美化,做出更漂亮的表格了,比如下面的

element table列样式_td_06

element table列样式_td_07

element table列样式_element table列样式_08