我試圖通過把他們position: relative
增加對<th>
幾個圖標,然後position
使用position: absolute
的<th>
內荷蘭國際集團的圖標爲::after
僞元素,並給予圖標作爲背景(因爲他們是精靈)。這適用於Google Chrome和Firefox,但不適用於Internet Explorer。問題與IE11多高度TH和僞元素的定位
這裏的演示該問題的片斷(這是可重複的只在Internet Explorer中,我的版本11):
* {font-family: 'Segoe UI';}
.arrow {border: 1px solid #ccc; padding: 5px; line-height: 1; background-color: #00f; color: #fff; position: relative; cursor: pointer; padding-right: 20px;}
.arrow-normal::after {width: 9px; height: 12px; margin-top: -6px;}
.arrow-up::after {width: 9px; height: 6px; margin-top: -3px;}
.arrow-down::after {width: 9px; height: 6px; margin-top: -3px; background-position: 0 -6px;}
.arrow::after {
top: 50%;
position: absolute;
right: 5px;
content: ' ';
display: block;
background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABQAAAAMCAYAAABiDJ37AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAnZJREFUeNpsk99rUmEYx1/l+Hvmj8HwQgQvvHKS0LqJQCOIMnTmqOb8UTfdDjb/iYneDAaCIhgSE/NnTOZNMAapkCFYbMEIuiswaHPq5tHj6XlsR3TsCw/nfR/e9/M+vw4RCAQEDWW325+0Wq0fDofDKhKJyMLCwthYlh1btVolpVKJHB4eklgsdlur1X4LBALPCoUCSSaTJJvNkgnM6XTaz0FwkYVP2+VyPRIKhTPASqVCDg4OSCQSWZqfn/8F11h4uLe5ufk8l8v9B6JWVlacl5eXF+yUOp3OOfjHUA7YbDbJzs7Oklqt/o0wziiKotfX11fL5TIha2trL/v9Ps3eIIB2fT7fMgeMx+P35+bm/kzDpozZ2Njw8xqNxkeDwXC32+22eSByJQTKZLJbJycnn81m80P0QRneQcp2uVz+F7aTsyjIUKbX65s8t9st1Gg0gsFgwE7BCLKhvryzs7MBREajv16vU0qlUsDn81kOeHV2vO/1egxlMpkYm82GL5DrwvpBRAy3h1qNisXigGvktCAgsri4OKJgVEqwuAOOzrUzLFyUSySSL7B+jI6tra14Pp9/ClGeQmQzKUN0MqPR+JVsb2/7R6MRc1NThsNhP5FIvOCasre390ChUJze1BRMOxgMvsGRIdFodBUinOk0TdO9VCrlgBmbjA08QPb39++pVKqZTkNNmVAo9Ap+CsKXSqU4sCmYfA9ALjB8/GYymdWjo6MPYrF4khY0iFit1sru7u4yDDZCsXE0wF57vd637Xab8NGJ0Fqt9h4idcOln+l02nV8fDwDQ2HnEWqxWD7BGZtOp/seDof9Ho8niTDM4p8AAwB6jpihgDknYAAAAABJRU5ErkJggg==");
}
<table>
<thead>
<tr>
<th class="arrow arrow-normal">Two Line<br />Column</th>
<th class="arrow arrow-up">Single</th>
<th class="arrow arrow-down">Three<br />Line<br />Column</th>
</tr>
</thead>
<tbody>
<tr>
<td>Item 1</td>
<td>Item 2</td>
<td>Item 3</td>
</tr>
</tbody>
</table>
當我在谷歌瀏覽器上運行,我得到預期輸出:
全部•谷歌瀏覽器中的圖標在中間完美對齊。
然而,在Internet Explorer中,問題在於,所有<th>
元素在內容不同時都會佔據正確的高度,但定位會混亂。
我看到的是,在Internet Explorer中,高度是正確的計算,但對於position
,調錶前的初始高度考慮在內。有什麼可以解決這個問題嗎?
注1:我也看着IE vertical centering bug with table-cell parent and absolutely positioned pseudo-element,這需要我用另一種元素,給position: relative
,但這是不可能在我的情況下,我的HTML是固定的,不能改變。它是由我無法控制的企業應用程序生成的。
注2:由於我已經知道每個元素的高度,因此我使用負邊距技術。
請讓我知道這是否可能。
兄弟,謝謝。我告訴過你,我不能改變HTML ......':(' –
@PraveenKumar啊,當我在注1中錯過了。 – TylerH