基於CSS屬性display:table的表格佈局的使用

項目改造中遇到DIV+CSS實現的table,新需求需要在表格使用單元格合併,網上調查返現CSS display:table實現的table表格,沒有單元格的屬性和樣式,經過一番思考,曲折現實了單元格的合併,即採用正行嵌套一個單獨的display:table的DIV,然後在嵌套的表格DIV內部通過控制行列數和行列的高度,實現單元格合併。個人建議全新實現使用<table> HTML標籤即可

一、CSS display屬性的表格佈局相關屬性的解釋:

  • table    此元素會作爲塊級表格來顯示(類似 <table>),表格前後帶有換行符。
  • table-row-group    此元素會作爲一個或多個行的分組來顯示(類似 <tbody>)。
  • table-header-group    此元素會作爲一個或多個行的分組來顯示(類似 <thead>)。
  • table-footer-group    此元素會作爲一個或多個行的分組來顯示(類似 <tfoot>)。
  • table-row    此元素會作爲一個表格行顯示(類似 <tr>)。
  • table-column-group    此元素會作爲一個或多個列的分組來顯示(類似 <colgroup>)。
  • table-column    此元素會作爲一個單元格列顯示(類似 <col>)
  • table-cell    此元素會作爲一個表格單元格顯示(類似 <td> 和 <th>)
  • table-caption    此元素會作爲一個表格標題顯示(類似 <caption>)

二、示例代碼

1、普通表格

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>display普通表格</title>
<style type="text/css">
.table, .table * {margin: 0 auto; padding: 0;font-size: 14px;font-family: Arial, 宋體, Helvetica, sans-serif;}
.table {display: table; width: 80%; border-collapse: collapse;}
.table-tr {display: table-row; height: 30px;}
.table-th {display: table-cell;font-weight: bold;height: 100%;border: 1px solid gray;text-align: center;vertical-align: middle;background-color:#E5E5E5;}
.table-td {display: table-cell; height: 100%;border: 1px solid gray; text-align: center;vertical-align: middle;}
</style>
</head>
<body>
	<div class="table">
		<div class="table-tr">
			<div class="table-th">省份/直轄市</div>
			<div class="table-th">GDP(億元)</div>
			<div class="table-th">增長率</div>
		</div>
		<div class="table-tr">
			<div class="table-td">廣東</div>
			<div class="table-td">72812</div>
			<div class="table-td">8.0%</div>
		</div>
		<div class="table-tr">
			<div class="table-td">河南</div>
			<div class="table-td">37010</div>
			<div class="table-td">8.3%</div>
		</div>
		<div class="table-tr">
			<div class="table-td">江蘇</div>
			<div class="table-td">70116</div>
			<div class="table-td">8.5%</div>
		</div>
	</div>
</body>
</html>
運行效果


2、列合併實現表格

實現思路:基於display:table的表格實現,沒有<table>的rowspan和colspan單元格合併的實現,所以曲折實現,將表格每行單獨嵌套一個獨立的表格,這樣在嵌套的獨立表格內部,單元格合併就能通過控制嵌套表格的行數和列數以及單元格的寬高來實現

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>基於display列合併表格</title>
<style type="text/css">
.table, .table * {margin: 0 auto; padding: 0;font-size: 14px;font-family: Arial, 宋體, Helvetica, sans-serif;}
.table {display: table; width: 80%; border-collapse: collapse;}

.table-tr {display: table-row; height: 30px;}
.table-th {display: table-cell;font-weight: bold;height: 100%;border: 1px solid gray;text-align: center;vertical-align: middle;background-color:#E5E5E5;}
.table-td {display: table-cell; height: 100%;}

.sub-table {width: 100%;height: 100%;display: table;}
.sub-table-tr {display: table-row; height: 100%;}
.sub-table-td {display: table-cell; height: 100%;border: 1px solid gray; text-align: center;vertical-align: middle;}

</style>
</head>
<body>

<div class="table">
	<div class="table-tr">
		<div class="table-td">
			<div class="sub-table">
				<div class="sub-table-tr">
					<div class="table-th" style="width: 40%;">省份/直轄市</div>
					<div class="table-th" style="width: 30%;">GDP(億元)</div>
					<div class="table-th" style="width: 30%;">增長率</div>
				</div>
			</div>
		</div>
	</div>
	<div class="table-tr">
		<div class="table-td">
			<div class="sub-table">
				<div class="sub-table-tr">
					<div class="sub-table-td" style="width: 40%;">廣東</div>
					<div class="sub-table-td" style="width: 30%;">72812</div>
					<div class="sub-table-td" style="width: 30%;">8.0%</div>
				</div>
			</div>
		</div>
	</div>
	<div class="table-tr">
		<div class="table-td">
			<div class="sub-table">
				<div class="sub-table-tr">
					<div class="sub-table-td" style="width: 40%;">河南</div>
					<div class="sub-table-td" style="width: 30%;">37010</div>
					<div class="sub-table-td" style="width: 30%;">8.3%</div>
				</div>
			</div>
		</div>
	</div>
	<div class="table-tr">
		<div class="table-td">
			<div class="sub-table">
				<div class="sub-table-tr">
					<div class="sub-table-td" style="width: 40%;">江蘇</div>
					<div class="sub-table-td" style="width: 30%;">70116</div>
					<div class="sub-table-td" style="width: 30%;">8.5%</div>
				</div>
			</div>
		</div>
	</div>
	<div class="table-tr">
		<div class="table-td">
			<div class="sub-table">
				<div class="sub-table-tr">
					<div class="sub-table-td" style="width: 70%;">各省/直轄市GDP平均增長率</div>
					<div class="sub-table-td" style="width: 30%;">8.26%</div>
				</div>
			</div>
		</div>
	</div>
</div>
</body>
</html>
運行效果


3、行合併表格

行合併的實現思路:與列合併的實現思路類似,將有單元格合併的列單獨嵌套一個display爲table的DIV,高度=單行高*單元格合併數目的倍數,同行的其他列同樣均單獨嵌套DIV,實例代碼如下

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>基於display的行合併表格</title>
<style type="text/css">
.table, .table * {margin: 0 auto; padding: 0;font-size: 14px;font-family: Arial, 宋體, Helvetica, sans-serif;}
.table {display: table; width: 80%; border-collapse: collapse;}

.table-tr {display: table-row; height: 30px;}
.table-th {display: table-cell;font-weight: bold;height: 100%;border: 1px solid gray;text-align: center;vertical-align: middle;background-color:#E5E5E5;}
.table-td {display: table-cell; height: 100%;}

.sub-table {width: 100%;height: 100%;display: table;}
.sub-table-tr {display: table-row; height: 100%;}
.sub-table-td {display: table-cell; height: 100%;border: 1px solid gray; text-align: center;vertical-align: middle;}

</style>
</head>
<body>

<div class="table">
	<div class="table-tr">
		<div class="table-td">
			<div class="sub-table">
				<div class="sub-table-tr">
					<div class="table-th" style="width: 40%;">省份/直轄市</div>
					<div class="table-th" style="width: 30%;">GDP(億元)</div>
					<div class="table-th" style="width: 30%;">增長率</div>
				</div>
			</div>
		</div>
	</div>
	<div class="table-tr">
		<div class="table-td">
			<div class="sub-table">
				<div class="sub-table-tr">
					<div class="sub-table-td" style="width: 40%;">廣東</div>
					<div class="sub-table-td" style="width: 30%;">72812</div>
					<div class="sub-table-td" style="width: 30%;">8.0%</div>
				</div>
			</div>
		</div>
	</div>
	<div class="table-tr" style="height:60px;">
		<div class="table-td">
			<div class="sub-table">
				<div class="sub-table-tr">
					<div class="sub-table-td" style="width: 40%; border: none;">
						<div class="sub-table">
							<div class="sub-table-tr" style="height:50%;">
								<div class="sub-table-td" style="width: 100%; height:50%;">
									河南
								</div>
							</div>
							<div class="sub-table-tr" style="height:50%;">
								<div class="sub-table-td" style="width: 100%; height:50%;">
									江蘇
								</div>
							</div>
						</div>
					</div>
					<div class="sub-table-td" style="width: 30%;border: none;">
						<div class="sub-table">
							<div class="sub-table-tr" style="height:50%;">
								<div class="sub-table-td" style="width: 100%; height:50%;">
									37010
								</div>
							</div>
							<div class="sub-table-tr" style="height:50%;">
								<div class="sub-table-td" style="width: 100%; height:50%;">
									70116
								</div>
							</div>
						</div>
					
					</div>
					
					<div class="sub-table-td" style="width: 30%;border: none;">
						<div class="sub-table">
							<div class="sub-table-tr">
								<div class="sub-table-td" style="width: 100%;">
									8.4%
								</div>
							</div>
						</div>
					</div>
				</div>
			</div>
		</div>
	</div>
	<div class="table-tr">
		<div class="table-td">
			<div class="sub-table">
				<div class="sub-table-tr">
					<div class="sub-table-td" style="width: 70%;">各省/直轄市GDP平均增長率</div>
					<div class="sub-table-td" style="width: 30%;">8.26%</div>
				</div>
			</div>
		</div>
	</div>
</div>
</body>
</html>
運行效果:

END

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章