时间:2021-05-08
两列布局项目中经常会用到,很多种方法可以做这样的效果
但是最方便的还是要属flex了,给外层父元素设置display:flex;然后子元素,宽度自适应的那个设置
flex-grow:1;,另外一个设置固定宽度就可以做到,一个固定另一个自适应了。
具体代码如下:
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>flex 宽度不生效</title></head><body> <style> * { margin: 0px; padding: 0px; } .box { display: flex; height: 100px; width: 100%; } .box .left { flex-grow: 1; background: red; } .box .right { width: 200px; background: yellow; } </style> <!-- 外层盒子 --> <div class="box"> <!-- 左侧 --> <div class="left"></div> <!-- 右侧 --> <div class="right"></div> </div></body></html>这段代码的运行结果就是上面截图那样,但是这个代码有一个小小的bug,那就是当我们左边(自适应那边)内部如果有内容,并且内容的宽度超过了left的宽度的时候,就会把右边(固定宽度)挤小,你会发现你给的固定宽度(例子中的200px)不生效了,或者出现滚动条。
我们在左边加一点内容,并且让他超出宽度。
运行结果:
内容超出,并出现了滚动条。这个问题很好解决,只需要在left上面加上溢出隐藏的属性,就可以了。
.box .left { flex-grow: 1; background: red; overflow: hidden; }但是问题又来了,右边出来了,可是它的宽度变小了,不足200了。
这个问题呢,其实也很容易,给右边的div(right)加上min-width:200px;就完美了。
这样不管你,什么屏幕,或者怎么拖放都能完美兼容了。。。
到此这篇关于css3中flex布局宽度不生效的解决的文章就介绍到这了,更多相关flex布局宽度不生效内容请搜索以前的文章或继续浏览下面的相关文章,希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
CSS中的Flex(弹性布局)可以很灵活的控制网页的布局,其中决定Flex布局内项目宽度/高度的是三个属性:flex-basis,flex-grow,flex-
display:box;box-flex是css3新添加的盒子模型属性,它的出现可以解决我们通过N多结构、css实现的布局方式。经典的一个布局应用就是布局的垂直
CSS3弹性伸缩布局简介2009年,W3C提出了一种崭新的方案----Flex布局(即弹性伸缩布局),它可以简便、完整、响应式地实现各种页面布局,包括一直让人很
Flexbox布局概念Flexbox布局(FlexibleBox或CSS3弹性布局),是CSS3中的一种新的布局模式,是可以自动调整子元素的高和宽,来很好的填充
适用于所有终端屏幕尺寸 使用CSS3的mediaqueries技术,网页布局宽度,操作界面,内容布局,图片大小等。可以面对不同的屏幕尺寸自动调整。电脑、版