CSS实现左边固定宽右边自适应布局怎样做
Admin 2022-11-30 群英技术资讯 1042 次浏览
本篇内容介绍了“CSS实现左边固定宽右边自适应布局怎样做”的有关知识,在实际项目的操作过程或是学习过程中,不少人都会遇到这样的问题,接下来就让小编带大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!这是一道面试题,你有多少种办法呢?
这里我们假设左边名为 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进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
干什么用的? 离线缓存为的是第一次请求后,根据manifest文件进行本地缓存,并且在下一次请求后进行展示(若有缓存的话,无需再次进行请求而是直接调用缓存),最根本的感觉是它使得WEB从online可以延伸到了offline领域。应用场景h5游戏及一些页面内容不经常会变动,相对较为固定的内容。一、基本概念离线缓存是HTML5新引入的技术,能够让你的Web应用程序指定哪些文件可以缓存在本地,使
这篇文章给大家分享的是有关css预处理器的内容,阅读完这篇大家会清楚css预处理器是什么,css预处理器有哪些和区别在哪。对新手学习和了解CSS有一定的帮助,感兴趣的朋友可以了解看看,接下来一起跟随小编来学习一下吧。
v-html可以在目标节点位置内部插入html子节点,跟节点的.innerHTML属性类似,使用方法如下: <!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><scriptsrc="https://cdn.staticfile.o
今天给大家分享的是用css3实现霓虹灯按钮的效果,实现效果如下,是不是非常的酷炫,那么这种类似霓虹灯的效果是怎样做的呢?接下来我们一起来了解看看实现代码。
我们在浏览网站的时候,可以看到一些网站页面的布局是头部固定,内容区域滚动的效果,那么这样的布局效果要怎样做呢?以前我们要实现页面头部固定布局是使用position:fixed,但是本文给大家分享一个更方便快捷的方法,就是使用flex布局,那么flex布局怎样实现头部固定的效果?下面我们一起来看看。
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008