Home >Web Front-end >CSS Tutorial >Why Do My Transformed Elements Snap Back on Hover?
In the realm of CSS, the elusive disappearing transform can be a puzzling phenomenon. Here, we delve into a specific instance of this issue, where an element's transformation appears to revert upon transition.
Consider the following CSS code:
<code class="css">.blockquote { transition: all 250ms ease-in-out; } .blockquote:hover .blockquote2 { transform: translateX(-20px); } .blockquote:hover .author { transform: translateX(200px); }</code>
Upon hovering over the blockquote element, the effect is strange. While the transform events do initially trigger, the translated elements ultimately snap back to their original positions.
The crux of this issue lies in the CSS property "display." CSS transforms are generally incompatible with elements set to display: inline. Therefore, to resolve the snapping problem, it's necessary to modify the display setting to display: inline-block.
Below is the updated code:
<code class="css">.blockquote { display: inline-block; transition: all 250ms ease-in-out; } .blockquote:hover .blockquote2 { transform: translateX(-20px); } .blockquote:hover .author { transform: translateX(200px); }</code>
With this change, the transition should function as expected, and the elements will maintain their transformed positions upon hovering.
The above is the detailed content of Why Do My Transformed Elements Snap Back on Hover?. For more information, please follow other related articles on the PHP Chinese website!