CSS布局如何实现左固定右自适应,有什么方法
Admin 2022-11-01 群英技术资讯 303 次浏览
这是一道面试题,你有多少种办法呢?
这里我们假设左边名为 left,宽度为 200 px,右边名为 right。即默认
.left { width: 200px; }
我的理解分四大类
flex 布局
grid 布局
绝对定位
双子元素 absolute
left:200px
+ width: 100%
左元素 absolute + 右元素 margin-left
margin-left: 200px
+ width: 100%
float 浮动
左元素左浮动,右元素不动
左元素左浮动,右元素右浮动
width: calc(100% - 200px)
)需要一个父元素做 flex 布局,且需要给它一个高度(撑开容器)
.father { display: flex; height: 200px; } .right { flex: 1; }
高级的布局方式,子元素不需要设置宽度,单单设置父元素属性即可。
.grid { display: grid; grid-template-columns: 200px 100%; height: 200px; }
需要给子元素设置宽高,不然撑不起来。右元素设置left: 200px
.father { position: relative; height: 200px; } .left { position: absolute; height: 200px; } .right { position: absolute; left: 200px; height: 200px; width: 100%; }
.father { position: relative; height: 200px; } .left { position: absolute; width: 200px; height: 200px; } .right { width: 100%; height: 200px; margin-left: 200px; }
前两种都需要有个父元素,但浮动不需要
左边浮动,下一个元素独占位置,并排一行
同样,需要设置高度,子元素才能撑开
.left { float: left; height: 200px; } .right { height: 200px; }
浮动不需要父元素,浮动就区别于正常文档流
我的理解是正常文档流是二维层面,而浮动相当于成了三维,区别于 Z 轴
右边元素有浮动不够,还需要设置宽度
.left { float: left; height: 200px; } .right { float: right; height: 200px; width: calc(100% - 200px); }
只要是 float 实现此功能的,都不需要父元素,以及自身都需要设置高度
简单来说,实现布局最好的方式是 flex,简单兼容现代浏览器和机型。当然,我是因为还没有学 grid(但 grid 要记得参数比较多)。绝对定位和浮动各有优缺点
各大方法 | 优缺点 | 需要什么 |
---|---|---|
flex | 布局简单 | 需要父元素、高度。子项 flex:1 |
grid | 布局最简单,但兼容性更现代 | 只需要父元素设置属性就好 |
绝对定位 | 兼容性更高 | 需要父元素做相对定位、高度 |
浮动 | 兼容性更高 | 不需要父元素,子项都需要宽高 |
float 区别于其他三种,不需要父元素做容器
grid 区别于其他三种,不需要设置子元素(左元素的)宽
绝对定位区别于其他三种,它的方法不仅要父元素有高,其子元素也要有高
flex 最简单
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
css定位叠放次序的使用注意:1、值越大,定位元素在层叠元素中越高。2、若取值相同,则按书写顺序,后来居上。3、后面的数字一定不能加单位。4、定位盒子才有z-index属性。
这篇文章主要介绍了移动端HTML5 input常见问题(小结),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
一、段落样式css中关于段落的样式主要有行高,缩进,段落对齐,文字间距,文字溢出,段落换行等。它们的具体语法如下:line-height:normal|lengthtext-indent:lengthtext-align:left|right|center|justifyletter-spacing:normal|l
这篇文章主要介绍了HTML+CSS相对宽度和绝对宽度冲突时的div解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
目前Firefox、Safari、Chrome以及Opera浏览器都支持文本选择属性,如果浏览器不支持该属性,会直接忽略它,所以不会产生任何不良的影响。下面就简单展示下这个改进UI体验的小技巧。二、改变默认选中颜色首先,简单点的例子,我们可以设置整个页面文本选中的基本样式,如下:代码如下复制代码::selection{background:#d3d3d3 ...
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008