Home >Web Front-end >CSS Tutorial >Can :hover Modify External CSS Classes?

Can :hover Modify External CSS Classes?

Susan Sarandon
Susan SarandonOriginal
2024-11-02 11:12:03467browse

Can :hover Modify External CSS Classes?

Can :hover Modify External CSS Classes?

In CSS, we can apply styling changes to elements on hover using the :hover selector. However, what if we want to modify the CSS of an element in a different class when another element is hovered?

As CSS selectors only target elements based on their hierarchy or relationships within the DOM, it's not possible to directly modify the CSS of an element outside of the current hover element's scope.

Options for Indirect Modifications

However, there are indirect approaches to achieve similar effects:

  • Parent-Child Relationship: If the element you want to modify (E) is a child of the hovered element (F), you can use the :hover selector on F to target E.
.item:hover .wrapper {
  /* Styles to be applied to '.wrapper' when '.item' is hovered */
}
  • Sibling Relationship: If E is a sibling of F (or a descendant of one of F's siblings), you can use the ~ sibling combinator in CSS.
.item:hover ~ .wrapper {
  /* Styles to be applied to '.wrapper' when '.item' or any of its siblings is hovered */
}

JavaScript Solution

If CSS solutions are not feasible, you can use JavaScript to manipulate the CSS properties of E based on the hover state of F.

<code class="javascript">document.querySelector('.item').addEventListener('mouseenter', () => {
  document.querySelector('.wrapper').style.backgroundColor = 'red';
});

document.querySelector('.item').addEventListener('mouseleave', () => {
  document.querySelector('.wrapper').style.backgroundColor = '';
});</code>

Conclusion

While CSS selectors alone cannot directly modify external classes, the parent-child or sibling relationship and JavaScript provide indirect solutions for achieving similar effects.

The above is the detailed content of Can :hover Modify External CSS Classes?. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn