【总结】:CSS常用的两栏布局方法(最全面)

.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

HTML不变

CSS:

.container {

height: 300px;

}

.left {

float: left;

/* 定宽 */

width: 200px;

height: 100%;

background-color: chartreuse;

}

.right {

/* 不设置宽度自适应 */

height: 100%;

overflow: hidden; /触发BFC条件/

background-color: coral;

}

原理:给正常元素添加BFC属性,正常元素就不会被遮挡,且环绕浮动元素排开

✳ 一波小总结:以上脱离文档流的方式(如浮动、定位),他们的大体思路都是: 先让左定宽元素脱离文档流,这样可以右列正常能够与左列脱离文档流的元素“站成一排”,此时左列元素还覆盖着右列元素,最后,我们只需要调整一下右列元素的外边距啊、定位啊什么的就可以完成啦~


方法四:flex布局

HTML不变

CSS:

.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布局

HTML不变

CSS:

/* 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

因为操作方式如上面演示一样,只是去掉左列宽度属性而已,因此就不一一赘述列举了。
操作方式:去掉左列宽度,左列的宽度根据内容进行自适应,从而实现“左列不定宽,右列自适应宽”的效果。
为什么只有这两种方式可以实现?
因为其他方式都是脱离文档流的方式(如:浮动、定位),内部元素无法撑开脱离文档流的盒子。

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!**

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

  • 22
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值