I am outputting a list of products in Magento, as a simple list wrapped in a table.
As this list can get quite long (100 products+), I've used the ideas from here to automatically split the table into two, to help with readability etc.
#container {
column-count:2;
-moz-column-count:2;
-webkit-column-count:2;
}
However, this method just flows the table into 2 columns. Does anyone know how I can get the table header to also repeat in the second column?
Using the linked answer, you can see this fiddle which shows where I am at: http://jsfiddle.net/J3VB5/51/
Check the Text Wrapping Setting It may sound odd, but the text wrapping setting for a table can affect its ability to repeat header rows. Text wrapping is used to wrap text around your table, and it appears that Word assumes such tables will be quite small. If your table is multiple pages, it obviously isn't small.
Any break in the table will prevent the header row from repeating.
Would an extra markup + CSS solution help?
Duplicate your header (with repeated columns) right above your current container.
<div id="container1">
<table id="tbl">
<thead>
<tr>
<th>header1</th>
<th>header2</th>
</tr>
<tr>
<th>header1</th>
<th>header2</th>
</tr>
</thead>
</table>
</div>
<div id="container">
<table id="tbl">
...
Hide the actual header in your table with CSS trickery
<table id="tbl">
<thead>
<tr class="dummy">
<th><span>header1</span></th>
<th><span>header2</span></th>
</tr>
...
CSS
#container1, #container {
column-count:2;
-moz-column-count:2;
-webkit-column-count:2;
}
.dummy > th > span {
display: block;
height: 0;
opacity: 0;
}
The solution is admittedly hacky. It works pretty well even with long header content.
Fiddle - http://jsfiddle.net/uqz76rL1/ Fiddle with a long header - http://jsfiddle.net/3343Lg4x/
However it will NOT work if your td content is what is driving the table layout as is obvious from this fiddle - http://jsfiddle.net/kezztx55/
So, if you have a fixed table layout (or if you can put in a dummy row in container1 containing the content that drives your column width) it will work.
I'll admit this took a while, but it works. So as an alternative to potatopeelings's answer, I present this CSS monster:
#container {
column-count:2;
-moz-column-count:2;
-webkit-column-count:2;
}
tbody tr:nth-child(7n+1) td{
white-space: pre;
}
tbody tr:nth-child(7n+1) td:first-child:before {
content:"Header 1 \A";
}
tbody tr:nth-child(7n+1) td:last-child:before {
content:"Header 2 \A";
}
tbody tr:nth-child(7n+1) td:before {
background-color:red;
height:20px;
width:100%;
}
<div id="container">
<table id="tbl">
<tbody>
<tr>
<td>aaaa</td>
<td>bbbb</td>
</tr>
<tr>
<td>aaaa</td>
<td>bbbb</td>
</tr>
<tr>
<td>aaaa</td>
<td>bbbb</td>
</tr>
<tr>
<td>aaaa</td>
<td>bbbb</td>
</tr>
<tr>
<td>aaaa</td>
<td>bbbb</td>
</tr>
<tr>
<td>aaaa</td>
<td>bbbb</td>
</tr>
<tr>
<td>aaaa</td>
<td>bbbb</td>
</tr>
<tr>
<td>aaaa</td>
<td>bbbb</td>
</tr>
<tr>
<td>aaaa</td>
<td>bbbb</td>
</tr>
<tr>
<td>aaaa</td>
<td>bbbb</td>
</tr>
<tr>
<td>aaaa</td>
<td>bbbb</td>
</tr>
<tr>
<td>aaaa</td>
<td>bbbb</td>
</tr>
<tr>
<td>aaaa</td>
<td>bbbb</td>
</tr>
</tbody>
</table>
</div>
This relies on several factors though.
Firstly, the current layout only works with 2 columns (it can work with more, just tweak a few things).
The main point: you need to have a defined maximum per column. Now I'm guessing you probably do have a maximum, however you did not specify one so I'm hoping you do.
You'll notice that I deleted the thead
tags, and to define your header titles, you'll need to use the content property in the css. The "\A" and white-space: pre;
are vital.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With