use*_*136 7 html css html-table border-spacing
我尝试删除Table1Header和Table2Header之间的空白区域.我尝试过border:0px,padding:0px和border-spacing:0px; 样式.Firefox和Opera告诉我,我的边框间距样式被用户代理样式(2px)所覆盖.如何强制浏览器使用我的样式?
<table class="tableGroup">
<tbody>
<tr>
<td>
<table>
<tbody>
<tr class="tableHeader">
<td><span class="tableHeader"><label>Table1Header</label></span>
</td>
</tr>
<tr class=" tableData">
<td>
<div class="ui-datatable">
<div>
<table>
<thead>
<tr>
<th>
<div><span><span class="ui-header-text">Table1Col1</span></span>
</div>
</th>
</tr>
</thead>
<tbody>
<tr>
<td><span>2</span>
</td>
</tr>
</tbody>
</table>
</div>
</div>
</td>
</tr>
</tbody>
</table>
</td>
<td>
<table>
<tbody>
<tr class="tableHeader">
<td><span class="tableHeader"><label>Table2Header</label></span>
</td>
</tr>
<tr class="tableData">
<td>
<div class="ui-datatable">
<div>
<table>
<thead>
<tr>
<th>
<div><span><span class="ui-header-text" >Table2Col1</span></span>
</div>
</th>
</tr>
</thead>
<tbody>
<tr>
<td><span>12345</span>
</td>
</tr>
</tbody>
</table>
</div>
</div>
</td>
</tr>
</tbody>
</table>
</td>
</tr>
</tbody>
</table>
span.tableHeader > label {
display: inline-block;
float:left;
line-height:30px;
padding-left:10px;
color: #202020;
font-size: 13px;
}
tr.tableHeader {
background-color: #EEEEEE;
}
table.tableGroup, table.tableGroup > tr > td > table {
border-spacing: 0px;
}
table.tableGroup div.ui-datatable th > div > span >span.ui-header-text {
color: #808080;
font-size: 11px;
}
table.tableGroup td, table.tableGroup th {
padding: 0px;
border: 0px;
}
Run Code Online (Sandbox Code Playgroud)
Mr.*_*ien 16
你可以简单地使用border-collapse: collapse;,甚至border-spacing: 0;可以
table { /* Will apply to all tables */
border-spacing: 0;
/* OR border-collapse: collapse; */
}
Run Code Online (Sandbox Code Playgroud)
您可以使用简单的元素选择器轻松覆盖useragent样式表.
如果要标准化样式,则应使用CSS重置
来到你的选择器,这对我来说似乎很脏,因为你瞄准桌子class .tableGroup和table嵌套在那下面
table.tableGroup, table.tableGroup > tr > td > table {
border-spacing: 0px;
}
Run Code Online (Sandbox Code Playgroud)
所以你最好用
table.tableGroup,
table.tableGroup table {
border-spacing: 0;
}
Run Code Online (Sandbox Code Playgroud)
浏览器不会告诉您您的border-spacing样式已被用户代理样式表覆盖。相反,它们可能表明它不会发生继承。这仅仅是由于某些样式表在元素上设置了属性而引起的。
您的规则未应用于内部元素的原因table是它与您的任何选择器都不匹配。选择器
table.tableGroup > tr > td > table
Run Code Online (Sandbox Code Playgroud)
不匹配它,因为tr元素永远不是 if 的子元素table,即使可能看起来是。根据 HTML 语法,存在一个中间tbody元素,即使其开始和结束标记缺失。以下选择器将匹配:
table.tableGroup > tbody > tr > td > table
Run Code Online (Sandbox Code Playgroud)
当然,table只要您希望所有table元素都按照规则设置样式,那么仅仅一个选择器就可以完成这项工作。