在html中給table加一個斜線的表頭有時是很有必要的,但是到底該怎么實現這種效果呢?總結了以下幾種方法:
1、UI背景圖實現
直接去找公司的UI,讓她做一張圖片,作為背景圖片放到這里,然后撐滿就可以了。是不是很簡單!!!
2、 css3中transform屬性
其實了解css3的朋友,一看到這個效果,腦子中瞬間出現的就是transform這個屬性,是的,這個確實可以,也很簡單,就是有一個問題要注意瀏覽器的兼容性問題,大家心里要要時刻保持着危機意識(IE還存在呢),如果你們公司的要求是只兼容chrome,那么,這個方法很適合你。
3、利用border-top和border-left
這種方法也很簡單,但是這種寫法有個明顯的問題:這種其實就是利用兩種顏色的不同的border划分表頭的斜線的,斜線兩邊的顏色不能相同,如果是做一些促銷活動之類的表格時可以用這種方法。但是如果我們需要斜線兩邊的顏色一樣時,這種做法是不適用的。
css:
1 table { 2 border-collapse: collapse; 3 border: 1px #eee solid; 4 width: 80%; 5 min-width: 300px; 6 margin: 0 auto; 7 } 8 th{ 9 border: 1px solid #ddd; 10 text-align: center; 11 height: 100px; 12 } 13 .th_head{/*寬高100px,100px*/ 14 width:200px; 15 position: relative; 16 } 17 .box{ 18 border-top: 100px #ff0 solid; /*上邊框寬度等於表格第一行行高*/ 19 border-left: 200px #0ff solid; /*左邊框寬度等於表格第一行第一格寬度*/ 20 } 21 .a,.b{ 22 font-style: normal; 23 display: block; 24 position: absolute; 25 width: 200px; 26 height: 50px; 27 line-height: 50px; 28 } 29 .a{ 30 top: 0px; left: 0px; 31 } 32 .b{ 33 top: 50px; left: 0px; 34 } 35 </style>
設計塢https://www.wode007.com/sites/73738.html
html:
1 <table> 2 <tr> 3 <th class="th_head"> 4 <div class="box"> 5 <em class="a">A</em> 6 <em class="b">B</em> 7 </div> 8 </th> 9 <th>C</th> 10 </tr> 11 </table>
4、css3的canvas
這種效果其實還可以用css3的另一個新的標簽canvas。將其作為畫布畫一條斜線是一種十分簡單的做法,就不詳細解釋了,但是也有一個問題,就是老生常談的兼容性問題了,如果只是兼容chrome,你想怎么辦都行(為什么我們公司一直要考慮可惡的IE,我也想只做兼容谷歌的項目啊)。
5、js的實現
1 <TABLE border=0 bgcolor="000000" cellspacing="1" width=400 2 style="margin-left: 100px;"> 3 <TR bgcolor="FFFFFF"> 4 <TD width="111" height="52"><table width="100%" height="100%" 5 border="0" cellpadding="0" cellspacing="0"> 6 <tr> 7 <td id="td1"></td> 8 <td>成績</td> 9 </tr> 10 <tr> 11 <td>姓名</td> 12 <td id="td2"></td> 13 </tr> 14 </table></TD> 15 <TD width="81">數學</TD> 16 <TD width="96">英語</TD> 17 <TD width="99">C語言</TD> 18 </TR> 19 <TR bgcolor="FFFFFF"> 20 <TD>張三</TD> 21 <TD>55</TD> 22 <TD>66</TD> 23 <TD>77</TD> 24 </TR> 25 <TR bgcolor="FFFFFF"> 26 <TD>李四</TD> 27 <TD>99</TD> 28 <TD>68</TD> 29 <TD>71</TD> 30 </TR> 31 <TR bgcolor="FFFFFF"> 32 <TD>王五</TD> 33 <TD>33</TD> 34 <TD>44</TD> 35 <TD>55</TD> 36 </TR> 37 </TABLE> 38 <script type="text/javascript"> 39 function a(x, y, color) { 40 document 41 .write("<img border='0' style='position: absolute; left: " 42 + (x) 43 + "; top: " 44 + (y) 45 + "; color: rgb(0, 136, 0);">"' src='px.gif' width=1 height=1>") 46 } 47 function getTop(tdobj) { 48 vParent = tdobj.offsetParent; 49 t = tdobj.offsetTop; 50 while (vParent.tagName.toUpperCase() != "BODY") { 51 t += vParent.offsetTop; 52 vParentvParent = vParent.offsetParent; 53 } 54 return t; 55 } 56 57 function getLeft(tdobj) { 58 vParent = tdobj.offsetParent; 59 t = tdobj.offsetLeft; 60 while (vParent.tagName.toUpperCase() != "BODY") { 61 t += vParent.offsetLeft; 62 vParentvParent = vParent.offsetParent; 63 } 64 return t; 65 } 66 function line(x1, y1, x2, y2, color) { 67 var tmp 68 if (x1 >= x2) { 69 tmp = x1; 70 x1 = x2; 71 x2 = tmp; 72 tmp = y1; 73 y1 = y2; 74 y2 = tmp; 75 } 76 for ( var i = x1; i <= x2; i++) { 77 x = i; 78 y = (y2 - y1) / (x2 - x1) * (x - x1) + y1; 79 a(x, y, color); 80 } 81 } 82 //line(1,1,100,100,"000000"); 83 line(getLeft(td1), getTop(td1), getLeft(td1) + td1.offsetWidth, 84 getTop(td1) + td1.offsetHeight, '#000000'); 85 line(getLeft(td2), getTop(td2), getLeft(td2) + td2.offsetWidth, 86 getTop(td2) + td2.offsetHeight, '#000000'); 87 </script>