Responsive Table

Hello Everyone, Normally in responsive mode like Tab, Mobile View we see the scrollable Table. But today in this blog, I will show you a simple Responsive Table without Scrollbar. Let’s start

Codesandbox Link:https://codesandbox.io/s/responsive-table-9wi8s-9wi8s?from-embed

Live Demo Link:https://9wi8s.csb.app/

Let’s See the Design:

The below design is the final output that you will get as the final result of this content.

HTML Part:
To make this I use a normal HTML table.

Here is the HTML code:

<table>
      <thead>
        <tr>
          <th>First Name</th>
          <th>Last Name</th>
          <th>Job Title</th>
          <th>Job Title</th>
          <th>Job Title</th>
          <th>Job Title</th>
          <th>Job Title</th>
          <th>Job Title</th>
        </tr>
      </thead>
      <tbody>
        <tr>
          <td>James</td>
          <td>Matman</td>
          <td>Chief Sandwich Eater</td>
          <td>Chief Sandwich Eater</td>
          <td>Chief Sandwich Eater</td>
          <td>Chief Sandwich Eater</td>
          <td>Chief Sandwich Eater</td>
          <td>Chief Sandwich Eater</td>
        </tr>
        <tr>
          <td>The</td>
          <td>Tick</td>
          <td>Crimefighter Sorta</td>
          <td>Crimefighter Sorta</td>
          <td>Crimefighter Sorta</td>
          <td>Crimefighter Sorta</td>
          <td>Crimefighter Sorta</td>
          <td>Crimefighter Sorta</td>
        </tr>
      </tbody>
    </table>

Now, Start with our simple CSS code

CSS Part:

table {
  width: 100%;
  border-collapse: collapse;
}

th {
  background: #c6c6c6;
  color: white;
  font-weight: bold;
  text-align: center;
}
td,
th {
  padding: 6px;
  border: 1px solid #ccc;
  text-align: left;
}
tr {
  border-bottom: 1px solid #ccc;
}

Responsive Part:

@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%;
  }

  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: "First Name";
  }
  td:nth-of-type(2):before {
    content: "Last Name";
  }
  td:nth-of-type(3):before {
    content: "Job Title";
  }
  td:nth-of-type(4):before {
    content: "Favorite Color";
  }
  td:nth-of-type(5):before {
    content: "Wars of Trek?";
  }
  td:nth-of-type(6):before {
    content: "Secret Alias";
  }
  td:nth-of-type(7):before {
    content: "Date of Birth";
  }
  td:nth-of-type(8):before {
    content: "Dream Vacation City afia";
  }
  td:nth-of-type(9):before {
    content: "GPA";
  }
  td:nth-of-type(10):before {
    content: "Arbitrary Data";
  }
}

By

Leave a Reply

Your email address will not be published. Required fields are marked *