解决给li添加border兄弟元素浮动的问题(添加border不浮动的方法)

本文探讨了在CSS布局中,当为li元素添加边框时,其兄弟元素出现抖动现象的原因及解决方案。通过理解盒模型计算原理,采用border:2px solid transparent属性,有效避免了元素大小的改变。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近笔者在写界面时遇到一个问题,给li添加border边框选中效果的时候,发现它的兄弟元素一直抖动.发现时浏览器的盒模式计算增加了元素的width

找了很多资料,说是给li元素添加box-sizing属性,结果还是不行

box-sizing属性是css3为了改善盒模型定义的,该属性能事先定义盒模式的尺寸解析方式,

box-sizing:content-box|border-box|inherit;

content-box:width/height=border+padding+content;

border-box:width/height=content

IE怪异模式(Quirks)虽然不规范,但是在变更border时不会重新计算大小.但是标准模式下会重新计算大小.所以想起来border的透明属性找到解决方法了

border:2px solid transparent

这样就不会改变盒子的大小了

解决方法最后这样子,给border添加透明边框,这样子只是改变了边框的颜色而已

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值