已解决
CSS 两栏布局
来自网友在路上 154854提问 提问时间:2023-10-23 04:21:17阅读次数: 54
最佳答案 问答题库548位专家为你答疑解惑
目录
CSS两栏布局(左列定宽,右列自适应宽)
方法一:浮动+margin
方法二:定位+margin
方法三:浮动+BFC
方法四:Flex布局
方法五:able布局
CSS两栏布局(左列不定宽,右列自适应宽)
CSS两栏布局(左列定宽,右列自适应宽)
方法一:浮动+margin
<div class="container"><div class="left">定宽</div><div class="right">自适应</div>
</div><style>/* 不给高度不行,不给宽度可以自适应 */
.container {height: 300px;
}
.left {float: left;/* 定宽 */width: 200px;height: 100%;background-color:chartreuse;
}.right {/* 不设置宽度自适应 */height: 100%;background-color:coral;margin-left: 200px;
}</style>
方法二:定位+margin
html不变
/* 不给高度不行,不给宽度可以自适应 */
.container {position: relative;height: 300px;
}
.left {position: absolute;left: 0;/* 定宽 */width: 200px;height: 100%;background-color:chartreuse;
}.right {/* 不设置宽度自适应 */height: 100%;/* 方法一:margin-left: 200px(只设置边距也可以实现) *//* 方法二:定位*/position:absolute;left: 200px;right: 0; /*不设置这个,宽度会缩在一起,不自适应展开*/background-color:coral;
}
方法三:浮动+BFC
.container {height: 300px;
}
.left {float: left;/* 定宽 */width: 200px;height: 100%;background-color: chartreuse;
}
.right {/* 不设置宽度自适应 */height: 100%;overflow: hidden; /*触发BFC条件*/background-color: coral;
}
原理:给正常元素添加BFC属性,正常元素就不会被遮挡,且环绕浮动元素排开。
以上
脱离文档流的方式
(如浮动、定位),他们的大体思路都是: 先让左定宽元素
脱离文档流,这样可以右列正常能够与左列脱离文档流的元素“站成一排”
,此时左列元素还覆盖着右列元素,最后,我们只需要调整一下右列元素
的外边距啊、定位啊什么的就可以完成
方法四:Flex布局
.container {display: flex;height: 300px;
}
.left {/* 定宽 */width: 200px;/*height: 100% 因为未脱离文档流,所以不用设置高度也行*/background-color: chartreuse;
}
.right {/* flex 属性是 flex-grow、flex-shrink 和 flex-basis 属性的简写属性。 */flex: 1;/*height: 100% 因为未脱离文档流,所以不用设置高度也行*/background-color:coral;
}
方法五:able布局
/* table布局:(display:table-cell后)子级容器默认是自动平分宽度沾满父级容器; */
.container {display: table;height: 300px;width: 100%;
}
.left {display: table-cell;/* 定宽 */width: 200px;/*height: 100% 因为未脱离文档流,所以不用设置高度也行*/background-color: chartreuse;
}
.right {/*height: 100% 因为未脱离文档流,所以不用设置高度也行*/display: table-cell;background-color: coral;
}
table布局只需要给父元素添加display:table属性,以及给两个子元素添加 display: table-cell属性即可
CSS两栏布局(左列不定宽,右列自适应宽)
方法一:flex
方法二:浮动+BFC
因为操作方式如上面演示一样,只是去掉左列宽度属性而已,因此就不一一赘述列举了。
操作方式:去掉左列宽度,左列的宽度根据内容进行自适应,从而实现“左列不定宽,右列自适应宽”的效果。
为什么只有这两种方式可以实现?
因为其他方式都是脱离文档流的方式(如:浮动、定位),内部元素无法撑开脱离文档流的盒子。
查看全文
99%的人还看了
相似问题
- (带教程)商业版SEO关键词按天计费系统:关键词排名优化、代理服务、手机自适应及搭建教程
- 【Java】ExcelWriter自适应宽度工具类(支持中文)
- matlab 小波自适应阈值去噪
- CSS实现背景图片全屏铺满自适应的方式(3种)
- echart宽度100px原因(解决el-tabs里的echarts图表宽度不自适应,只有100px问题)
- 圣杯布局/双飞翼布局/flex/grid等,实现CSS三栏自适应布局的几种方法
- Unity之UI、模型跟随鼠标移动(自适应屏幕分辨率、锚点、pivot中心点)
- (自适应手机端)响应式新闻博客知识类pbootcms网站模板 自媒体运营博客网站源码下载
- [迁移学习]DA-DETR基于信息融合的自适应检测模型
- CSS3媒体查询与页面自适应
猜你感兴趣
版权申明
本文"CSS 两栏布局":http://eshow365.cn/6-22139-0.html 内容来自互联网,请自行判断内容的正确性。如有侵权请联系我们,立即删除!