hover后元素边框变粗,样式被挤压?一招帮你解决,快收藏备用!

简介: 【10月更文挑战第15天】hover后元素边框变粗,样式被挤压?一招帮你解决,快收藏备用!

背景简介

大家好,我是石小石!最近开发中遇到这样一个需求:

hover卡片后,边框由原来的1px变成2px,且颜色由灰色变为蓝色。

hover改变样式,这太easy了!

.work-order-card {
   
    padding: 8px 16px 16px 16px;
    border-radius: 8px;
    border: 1px solid #e1e5eb;
    width: 296px;
    transition: all 0.2s ease;
    &:hover {
   
        border: 2px solid #64A6F7;
        transition: all 0.2s ease;
    }
}
AI 代码解读

但实际做完后,我们会发现一个问题,样式不够丝滑:

hover后元素的内边距发生变化,中间区域尺寸被挤压,从而导致过渡动画很生硬!

这个问题在前端开发中应该比较常见,我就简单分享一下自己的解决方案吧。

如何解决

要想解决这个问题,本质就是让hover前后,中间核心区域的位置不随边框、边距的变化而变化

场景一:边框从无到有

最简单的场景,就是一开始没有边框,后来有边框。

这种最容易处理,我们只需要给盒子设置和hover后同样粗细的边框,颜色设置透明即可。

.work-order-card {
   
    padding: 8px 16px 16px 16px;
    border-radius: 8px;
    border: 2px solid transparent;
    width: 296px;
    transition: all 0.2s ease;
    &:hover {
   
        border: 2px solid #64A6F7;
        transition: all 0.2s ease;
    }
}
AI 代码解读

场景二:边框粗细发生变化

比较麻烦的场景,如文章一开始说的场景,hover后,边框从1px变成2px。这种情况,hover盒子的padding一定会变化(注意大盒子尺寸是固定的),必然会导致内部元素被挤压,位置改变。

动态padding

当然,聪明的你可能计算hover后的padding

.work-order-card {
   
    padding: 8px 16px 16px 16px;
    border-radius: 8px;
    border: 1px solid #E1E5EB;
    width: 296px;
    &:hover {
   
        padding: 7px 15px 15px 15px;
        border: 2px solid #64A6F7;
    }
}
AI 代码解读

不加过渡动画时,看着挺不错

但加上transition过渡效果,那就原形毕露!

.work-order-card {
   
    padding: 8px 16px 16px 16px;
    border-radius: 8px;
    border: 1px solid #E1E5EB;
    width: 296px;
    transition: all 0.2s ease;
    &:hover {
   
        padding: 7px 15px 15px 15px;
        border: 2px solid #64A6F7;
        transition: all 0.2s ease;
    }
}
AI 代码解读

不设置padding,居中核心内容

如果盒子的尺寸都能确定,最好的方式,还是使用flex布局,让中间的核心区域(下图红色部分)永远居中!这样,无论边框怎么变,中间的位置永远不变,自然就解决了元素被挤压的问题!

<div class="work-order-card">
    <div class="center-box">
          <!-- 子元素 -->
    </div>
</div>
AI 代码解读
.work-order-card {
   
    border-radius: 8px;
    border: 1px solid #E1E5EB;
    width: 296px;
    height: 214px;
    transition: all 0.2s ease;
    &:hover {
   
        border: 2px solid #64A6F7;
        transition: all 0.2s ease;
    }
    .center-box{
   
        width: 264px;
    }
}
AI 代码解读

注意:这种实现方式,要求最外层的盒子宽高是固定的,内部盒子宽度也需要固定。

总结

针对hover某个元素,其边框变粗导致内部元素被挤压的问题,这篇文章提供了三个解决方案:

  • 边框从无到有,改变原始边框透明度即可
  • 边框hover尺寸变化:

    1. 如果不要求过渡效果,hover后可以计算padding
    2. 如果需要过渡效果,使用felx布局居中核心区域即可

如果大家有更好的方案,可以评论区分享一下。

相关文章
|
8月前
【奇技淫巧】实现flex布局中,单独某个元素挪到右侧、底部,与其他元素排列不同,就像是个另类。(主要是用到margin-left和align-self)
【奇技淫巧】实现flex布局中,单独某个元素挪到右侧、底部,与其他元素排列不同,就像是个另类。(主要是用到margin-left和align-self)
CSS布局:浮动 (结构伪类选择器、伪元素、标准流、浮动、清除浮动)
CSS布局:浮动 (结构伪类选择器、伪元素、标准流、浮动、清除浮动)
102 0
除了伪元素清除法,还有哪些方法可以解决浮动布局的高度塌陷问题
【10月更文挑战第27天】不同的方法适用于不同的场景和布局需求,在实际开发中,需要根据具体情况选择最合适的方法来解决浮动布局的高度塌陷问题。
移动端的技术选项,流式布局就是宽度给百分比,流式布局为了防止无限制缩小,要加最小宽度
移动端的技术选项,流式布局就是宽度给百分比,流式布局为了防止无限制缩小,要加最小宽度
如何实现侧边两栏宽度固定,中间栏宽度自适应的布局?——双飞翼布局、圣杯(Holy Grails)布局
如何实现侧边两栏宽度固定,中间栏宽度自适应的布局?——双飞翼布局、圣杯(Holy Grails)布局
93 0
echarts tooltip设置正常却无法显示被遮挡设置层级堆叠顺序的问题解决方案
echarts tooltip设置正常却无法显示被遮挡设置层级堆叠顺序的问题解决方案
608 0
css动画:文字向上移动并逐渐消失 点击按钮显示+1上移淡出
css动画:文字向上移动并逐渐消失 点击按钮显示+1上移淡出
1138 0
css动画:文字向上移动并逐渐消失 点击按钮显示+1上移淡出
一个元素纯CSS实现开关按钮【介绍box-shadow、单边或多重阴影、appearance属性】
借助checkbox表单元素、:checked伪类、::before/::after伪元素,就可以只需一个input[type="checkbox"]元素,通过纯CSS实现Switch开关效果的按钮.
529 0
一个元素纯CSS实现开关按钮【介绍box-shadow、单边或多重阴影、appearance属性】
每日一学—设置页面文字大小随屏幕大小变化而变化(rem布局)
每日学一点加强技术水平,夯实基础。 阅读这篇文章,一起学习rem布局吧。
424 0
每日一学—设置页面文字大小随屏幕大小变化而变化(rem布局)
CSS 奇技淫巧 | 巧妙实现文字二次加粗再加边框
CSS 奇技淫巧 | 巧妙实现文字二次加粗再加边框
354 0
CSS 奇技淫巧 | 巧妙实现文字二次加粗再加边框

热门文章

最新文章