html table表格斜線表頭的實現方法總匯


在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>
36 html:
37 
38 <table>  
39     <tr>  
40         <th class="th_head">  
41             <div class="box">  
42                 <em class="a">A</em>
43                 <em class="b">B</em>  
44             </div>  
45         </th>  
46         <th>C</th>    
47     </tr>   
48 </table>

設計塢https://www.wode007.com/sites/73738.html

 

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>

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM