Aligning text in a table with CSS
I would use classes in this instance. You could get fancy but this is the best way for supporting.
.alignright { text-align: right; }
.alignleft { text-align: left; }
HTML
<td class="alignright"> </td>
<td class="alignleft"> </td>
You could go further by adding padding, margins and further classes. Depending on your TABLE css you might need to add some padding so that the cells aren't all padding: 0 and not showing any alignment.
You can either use :first-child
to target the cells in the first column:
td {
text align: left;
}
td:first-child {
text-align: right;
}
But :first-child
: doesn’t work in IE 6, so you might want to add a class to the cells in the first column, and use that instead:
<table>
<tr><td class="first">Previous:</td><td>Link 1</td></tr>
<tr><td class="first">Next:</td><td>Link 2</td></tr>
</table>
td {
text align: left;
}
td.first {
text-align: right;
}
As written, this will apply to all <td>
elements, so you might also want to add a class to your table and limit the styles to <td>
s in that table:
<table class="simple">
<tr><td class="first">Previous:</td><td>Link 1</td></tr>
<tr><td class="first">Next:</td><td>Link 2</td></tr>
</table>
table.simple td {
text align: left;
}
table.simple td.first {
text-align: right;
}
As an alternative and given your scenario and if you are able to - why don't you replace the <td>
's in your second column with <th>
's and then the CSS will be really simple:
td { text-align:right; }
th { text-align:left; }