html - HTML 边框出现在单元格之外
问题描述
这是小提琴:https ://jsfiddle.net/uf23rtcs/
table {
margin: auto auto;
border-collapse: collapse;
}
td, th {
vertical-align: center;
text-align: center;
border: 1px solid black;
}
.test {
border: 2px solid red;
}
.borderless {
border: none;
width: 10px;
}
<table>
<thead>
<tr>
<th>Header 1</th>
<th class="borderless"></th>
<th>Header 2</th>
<th>Header 3</th>
<th class="borderless"></th>
<th>Header 4</th>
<th>Header 5</th>
</tr>
</thead>
<tbody>
<tr>
<td>Cell 1, 1</td>
<td rowspan="4" class="borderless"></td>
<td colspan="2" class="test">Cell 1, 3</td>
<td rowspan="4" class="borderless"></td>
<td>Cell 1, 6</td>
<td>Cell 1, 7</td>
</tr>
<tr>
<td>Cell 2, 1</td>
<td>Cell 2, 3</td>
<td>Cell 2, 4</td>
<td>Cell 2, 6</td>
<td rowspan="3">Cell 2, 7</td>
</tr>
<tr>
<td>Cell 3, 1</td>
<td rowspan="2">Cell 3, 3</td>
<td>Cell 3, 4</td>
<td rowspan="2">Cell 3, 6</td>
</tr>
<tr>
<td>Cell 4, 1</td>
</tr>
</tbody>
</table>
现在这是一个相当简单的表格,但是,我不知道如何使单元格 1、3 的边框不延伸到底部,因为我需要单元格 3、4 下方的空间是无边框的。
我想出的唯一解决方案是,如果我在该位置放置另一个无边界单元格,但我还需要它没有任何表格数据。我怎样才能解决这个问题?
border-collapse
当我将设置分开时(这是我不需要的),它似乎也能以某种方式工作。
谢谢你。
解决方案
只是不要使用行跨度......如果可能的话。
table {
margin: auto auto;
border-collapse: collapse;
}
td,
th {
vertical-align: center;
text-align: center;
border: 1px solid black;
}
.test {
border: 2px solid red;
}
.borderless {
border: none;
width: 10px;
}
<table>
<thead>
<tr>
<th>Header 1</th>
<th class="borderless"></th>
<th>Header 2</th>
<th>Header 3</th>
<th class="borderless"></th>
<th>Header 4</th>
<th>Header 5</th>
</tr>
</thead>
<tbody>
<tr>
<td>Cell 1, 1</td>
<th class="borderless"></th>
<td colspan="2" class="test">Cell 1, 3</td>
<td class="borderless"></td>
<td>Cell 1, 6</td>
<td>Cell 1, 7</td>
</tr>
<tr>
<td>Cell 2, 1</td>
<th class="borderless"></th>
<td>Cell 2, 3</td>
<td>Cell 2, 4</td>
<th class="borderless"></th>
<td>Cell 2, 6</td>
<td rowspan="3">Cell 2, 7</td>
</tr>
<tr>
<td>Cell 3, 1</td>
<th class="borderless"></th>
<td rowspan="2">Cell 3, 3</td>
<td>Cell 3, 4</td>
<th class="borderless"></th>
<td rowspan="2">Cell 3, 6</td>
</tr>
<tr>
<td>Cell 4, 1</td>
<th class="borderless"></th>
</tr>
</tbody>
</table>
推荐阅读
- javascript - 使用 Ionic 4 + angular 的时间记录器
- python - Django annotate 在内存中返回结果
- php - 选择查询以从数据库中获取数据
- r - R:限制排列比使用 for 循环更有效
- python - Python是如何执行的?
- postgresql - 具有内部连接的 Postgre 交叉表函数具有不匹配的值
- firebase - Firebase 自定义事件限制是否会影响到 Google Analytics 的数据
- spring-boot - Jacoco 与 Spring Boot 应用程序的集成在检测时出现错误
- kubernetes - 将 kiali 仪表板的时间范围从 6 小时增加到更高的数字
- java - 在不同的 chrome 选项卡中运行测试方法