如何在网页交互中使用纯CSS实现元素悬停时宽度不变且内容内缩并显示图标的效果?

在网页交互设计中,如何在元素悬停时保持其宽度不变,同时使内容内缩并显示图标,是一个常见的需求,尤其当元素宽度受动态数据影响时,实现这一效果更为复杂。本文将探讨如何通过css实现这种效果,并展示如何在悬停时使内容内缩并显示图标。

问题描述

假设我们有一个元素,其内容由变量data决定,宽度会随着data的长度变化而变化。我们希望在鼠标悬停在这个元素上时,保持其宽度不变,同时在元素内部显示一个图标,并让原有的文本内容向内挤压,生成省略号,类似于3….的效果。

尝试与挑战

最初尝试是通过JavaScript编写一个组件,动态设置和重置元素的宽度。这种方法虽然可行,但我们希望找到一种更简洁的纯css解决方案。

纯CSS解决方案

通过纯CSS,我们可以实现悬停时宽度不变,内容内缩并显示图标的效果。以下是实现这种效果的html和CSS代码:

HTML结构

<div class="fonttext">   ABCabcdsfes<i class="texticon">?</i>DEFGHIGK </div>

CSS样式

.fonttext {   position: relative;   display: inline-block;   overflow: hidden;   vertical-align: bottom;   border: 2px dashed red;   box-sizing: border-box;   border-radius: 4px; }  .texticon {   position: absolute;   width: 20px;   height: 100%;   background-color: #fff;   border: 2px dashed red;   font-style: normal;   right: -21px;   border-left: none;   cursor: pointer;   border-radius: 4px;   top: -2px;   display: inline-table; }  .texticon:hover {   background-color: #2d77ed; }  .fonttext:hover {   overflow: visible;   border-top-right-radius: 0;   border-bottom-right-radius: 0;   border-right-color: transparent; }  .fonttext:hover .texticon {   border-top-left-radius: 0;   border-bottom-left-radius: 0;   border-left-color: transparent; }

如何在网页交互中使用纯CSS实现元素悬停时宽度不变且内容内缩并显示图标的效果?

立即学习前端免费学习笔记(深入)”;

效果说明

  • 初始状态:元素显示正常文本内容,图标隐藏在元素右侧。
  • 悬停状态:当鼠标悬停在元素上时,元素的overflow属性变为visible,使得图标显示出来。同时,文本内容向内挤压,产生省略号效果。

通过这种方法,我们可以实现元素悬停时宽度不变,内容内缩并显示图标的效果。这种纯CSS的解决方案不仅简洁高效,还避免了使用JavaScript带来的性能开销。

© 版权声明
THE END
喜欢就支持一下吧
点赞6 分享