這篇文章主要講解了“怎么用純CSS實(shí)現(xiàn)表格響應(yīng)式布局”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“怎么用純CSS實(shí)現(xiàn)表格響應(yīng)式布局”吧!
目前創(chuàng)新互聯(lián)建站已為上千的企業(yè)提供了網(wǎng)站建設(shè)、域名、雅安服務(wù)器托管、網(wǎng)站托管、服務(wù)器租用、企業(yè)網(wǎng)站設(shè)計(jì)、桃城網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。
布局效果:
簡單解析一下效果:
在屏幕視口較為寬時(shí),表現(xiàn)為一個(gè)整體 Table 的樣式
而當(dāng)屏幕視口寬度較小時(shí),原 Table 的每一行數(shù)據(jù)單獨(dú)拆分為一個(gè) Table 進(jìn)行展示
很有意思的一個(gè)響應(yīng)式布局,讓信息在小屏幕下得到了一種不錯(cuò)的展示。
那么,僅僅使用 CSS 的話,能否實(shí)現(xiàn)這樣一個(gè)布局呢?答案是可以的。
首先,肯定會(huì)用到媒體查詢,這個(gè)不難看出。另外,我們觀察下拆分后的每一組數(shù)據(jù):
都會(huì)存在一組原本整體一個(gè) Table 時(shí)的表頭信息,主要的難點(diǎn)就是在這里,我們?nèi)绾卧诓鸱殖梢粋€(gè)一個(gè)的子 Table 展示時(shí),同時(shí)展示這些表頭信息?
首先,我們先實(shí)現(xiàn)常規(guī)寬屏下的 HTML 及對(duì)應(yīng)的 CSS。
比較簡單,這里沒有什么特殊之處,使用 得到這樣一個(gè)簡單的 Table: 下一步也很簡單,設(shè)定合適的閾值(視實(shí)際業(yè)務(wù)情況而定),使用媒體查詢將單個(gè) Table 拆分成多個(gè)子 Table。 這里做的事情也非常簡單: 利用媒體查詢,設(shè)定屏幕寬度小于 去掉原本表格的 將原本的一行 將原本的一行內(nèi)的 好,這樣,再屏幕寬度小于 下面一步,也就是最為關(guān)鍵的一步,我們?nèi)绾卧谧?table 的每一行,也就是 這里其實(shí)也非常簡單,只是簡單的運(yùn)用了偽元素,極其可以讀取 HTML 標(biāo)簽屬性的小特性實(shí)現(xiàn)。 我們只需要簡單改造一下代碼,給每個(gè) 接著,借助 td 的偽元素,實(shí)現(xiàn)表頭信息的展示即可: 這里,我們核心的知識(shí)點(diǎn)就是利用了元素的偽元素可以在 假設(shè)一個(gè) HTML 標(biāo)簽定義為: 那么該 div 對(duì)應(yīng)的偽類如果設(shè)置了 這樣,我們在小屏幕下,就得到了這樣一種效果: 完整的效果,即如題圖所示: 感謝各位的閱讀,以上就是“怎么用純CSS實(shí)現(xiàn)表格響應(yīng)式布局”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對(duì)怎么用純CSS實(shí)現(xiàn)表格響應(yīng)式布局這一問題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注! 標(biāo)簽或者使用 div、ul 等標(biāo)簽進(jìn)行模擬一個(gè)表格都可以。
Account
Due Date
Amount
Period
// ... 重復(fù)多組
Visa - 3412
04/01/2016
$1,190
03/01/2016 - 03/31/2016
使用媒體查詢將單個(gè) Table 拆分成多個(gè)
@media screen and (max-width: 600px) {
table {
border: 0;
}
table thead {
display: none;
}
table tr {
display: block;
margin-bottom: 10px;
}
table td {
border-bottom: 1px solid #ddd;
display: block;
}
}
600px
的樣式 表頭,直接隱藏即可
,設(shè)置為 display: block
, 并且設(shè)置一個(gè)下邊距,使之每一個(gè)分開,設(shè)置為 display: block
,這樣,它們就會(huì)豎向排列,使每一個(gè) 形成新的一個(gè)子 table 600px
時(shí),我們就得到了這樣一個(gè) Table:借助偽元素及其特性,實(shí)現(xiàn)表頭信息展示
內(nèi),再展示原本的表頭信息呢? 的 HTML,帶上與之對(duì)應(yīng)的表頭列描述信息:
// 上方信息保持一致
Visa - 3412
04/01/2016
$1,190
03/01/2016 - 03/31/2016
// ... 每個(gè) tr 進(jìn)行同樣的處理
Visa - 6076
03/01/2016
$2,443
02/01/2016 - 02/29/2016
@media screen and (max-width: 600px) {
// ... 保持一致
table td {
position: relative;
display: block;
text-align: right;
}
table td::before {
position: absolute;
left: 10px;
right: 0;
content: attr(data-label);
}
}
content
屬性里,讀取其 HTML 元素內(nèi)的屬性內(nèi)容,并進(jìn)行展示的知識(shí)點(diǎn)。content: attr(data-msg)
,就可以讀取到 data-msg 的值,相當(dāng)于 content:"ABC"
網(wǎng)頁題目:怎么用純CSS實(shí)現(xiàn)表格響應(yīng)式布局
網(wǎng)站路徑:http://weahome.cn/article/pehheg.html
其他資訊