Skip to content

Instantly share code, notes, and snippets.

@jcamachott
Last active February 11, 2016 16:09
Show Gist options
  • Save jcamachott/e78db3d96d78ae6d2c54 to your computer and use it in GitHub Desktop.
Save jcamachott/e78db3d96d78ae6d2c54 to your computer and use it in GitHub Desktop.
Responsive tables - css only
/*
Taken from https://css-tricks.com/responsive-data-tables/
*/
@media
only screen and (max-width: 760px),
(min-device-width: 768px) and (max-device-width: 1024px) {
/* Force table to not be like tables anymore */
table, thead, tbody, th, td, tr {
display: block;
}
/* Hide table headers (but not display: none;, for accessibility) */
thead tr {
position: absolute;
top: -9999px;
left: -9999px;
}
tr { border: 1px solid #ccc; }
td {
/* Behave like a "row" */
border: none;
border-bottom: 1px solid #eee;
position: relative;
padding-left: 50% !important;
}
td:before {
/* Now like a table header */
position: absolute;
/* Top/left values mimic padding */
top: 6px;
left: 6px;
width: 45%;
padding-right: 10px;
white-space: nowrap;
}
/*
Label the data
*/
td:nth-of-type(1):before { content: "Model"; }
td:nth-of-type(2):before { content: "Qualifying Income"; }
td:nth-of-type(3):before { content: "Price"; }
td:nth-of-type(4):before { content: "Discount"; }
td:nth-of-type(5):before { content: "Loan"; }
td:nth-of-type(6):before { content: "84 mths"; }
td:nth-of-type(7):before { content: "Insurance"; }
/* May need these lines below for 'heading rows'
/*
td[colspan="6"], td[colspan="7"] {
display: none !important;
}
*/
}
/* Smartphones (portrait and landscape) ----------- */
@media only screen
and (min-device-width : 320px)
and (max-device-width : 480px) {
body {
padding: 0;
margin: 0;
width: 100%;
}
table {
padding: 0;
margin: 0;
width: 320px; }
}
/* iPads (portrait and landscape) ----------- */
@media only screen and (min-device-width: 768px) and (max-device-width: 1024px) {
body {
width: 100%;
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment