


Can I use `col`, `colgroup`, and CSS `:hover` to highlight more than just a single table cell?
Can col, colgroups and the css "hover" pseudoclass be used for more than just a single cell?
To highlight table rows and columns on mouse hover, CSS pseudo-classes like ":hover" can be used. But what if you want to highlight not just a single cell, but an entire row or column, including the headers?
A pure CSS solution can achieve this using the ::before and ::after pseudo-elements. These elements add content before and after the selected element, respectively. Here's how:
-
Create Highlight Elements:
- Add ::before for row highlighting and ::after for column highlighting after the relevant elements (e.g., tr, td, th).
- Use absolute positioning to allow these elements to extend anywhere.
- Position them outside the element's bounds using negative values for left/top (::before) or left/bottom (::after).
- Set a larger width/height to cover the entire row/column.
-
Hide Highlight Overflow:
- Prevent the highlight elements from overflowing the table by setting overflow: hidden on the table.
- This keeps the table area clean while ensuring the highlight extends beyond individual cells.
-
Add Row/Column Selectors:
- To highlight only the current row or column, use the ::before and ::after elements on :hover th (headers) and :hover .row / .col (class-based selectors for rows/columns).
The CSS code below implements these principles:
table { overflow: hidden; } td, th, .row, .col { cursor: pointer; padding: 10px; position: relative; } td:hover::before, .row:hover::before { background-color: #FFA; content: '<pre class="brush:php;toolbar:false"><table> <tr> <th></th><th>50kg</th><th>55kg</th><th>60kg</th><th>65kg</th><th>70kg</th> </tr> <tr class="row"> <th class="row">160cm</th><td>20</td><td>21</td><td>23</td><td>25</td><td>27</td> </tr> <tr class="row"> <th class="row">165cm</th><td>18</td><td>20</td><td>22</td><td>24</td><td>26</td> </tr> </table>
The HTML remains largely unchanged, but includes class names for rows and columns:
This solution works in modern browsers, extending the hover highlight effect to entire rows and columns elegantly.
The above is the detailed content of Can I use `col`, `colgroup`, and CSS `:hover` to highlight more than just a single table cell?. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

It's out! Congrats to the Vue team for getting it done, I know it was a massive effort and a long time coming. All new docs, as well.

I'd say "website" fits better than "mobile app" but I like this framing from Max Lynch:

I had someone write in with this very legit question. Lea just blogged about how you can get valid CSS properties themselves from the browser. That's like this.

The other day, I spotted this particularly lovely bit from Corey Ginnivan’s website where a collection of cards stack on top of one another as you scroll.

If we need to show documentation to the user directly in the WordPress editor, what is the best way to do it?

There are a number of these desktop apps where the goal is showing your site at different dimensions all at the same time. So you can, for example, be writing

CSS Grid is a collection of properties designed to make layout easier than it’s ever been. Like anything, there's a bit of a learning curve, but Grid is

Questions about purple slash areas in Flex layouts When using Flex layouts, you may encounter some confusing phenomena, such as in the developer tools (d...
