CSS:两列布局

2024-02-06 21:28
文章标签 布局 css frontend 两列

本文主要是介绍CSS:两列布局,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

两列布局是指一列宽度固定,另一列自适应。效果如下:
在这里插入图片描述
HTML:

<div class="container clearfix"><div class="left"></div><div class="right"></div>
</div>

公共 CSS:

.container {width: 400px;height: 200px;
}.left {width: 100px;height: 200px;background-color: orange;
}.right {height: 200px;background-color: #d0e4fe;
}

一. float 浮动

方法一:float + calc()

.left {float: left;
}.right {float: left;width: calc(100% - 100px);
}/* 清除浮动 */
.clearfix::after {content: '';display: block;height: 0;clear: both;visibility: hidden;
}

注意事项:

如果父元素的高度没有设置,默认情况下,父元素的高度会被子元素撑高。如果子元素设置浮动,脱离文档流,就无法撑开父元素的高度,导致父元素高度塌陷,即父元素的高度变为 0,导致页面布局混乱。

示例如下:

<style>.container {width: 300px;border: 1px red solid;}.box1 {width: 100px;height: 100px;background-color: orange;}.box2 {width: 100px;height: 150px;background-color: #d0e4fe;}
</style><div class="container"><div class="box1"></div>
</div><div class="box2"></div>

在这里插入图片描述

此时,父元素 container 的高度被子元素 box1 的高度撑开。

box1 开启浮动后,效果如下:

.box1 {float: left;
}

在这里插入图片描述

此时 box1 脱离文档流,父元素的高度塌陷为 0,导致标准流中的 box2 位置上移,与 box1 重叠。因此,开启浮动造成的父元素高度塌陷会影响浮动元素之后元素的布局。

解决方案:

  1. 给父元素设置高度,可以避免高度塌陷,但也无法自适应子元素的高度。

  2. 将父元素的 overflow 属性设置为非 visible 的值,如 hidden 来开启 BFC。

    BFC(Block Formatting Context) 是一个 CSS 概念。BFC 是指浏览器中创建的一个独立的渲染区域,这个区域拥有自己的渲染规则,它决定了其子元素如何定位,以及与其他元素的相互关系和作用。简单来说,BFC 就是一个完全独立的空间(布局环境),让空间里的子元素不会影响到外面的布局

  3. 在高度塌陷的父元素最后增加一个空的 div,给其设置 clear: both; 清除浮动。

<div class="container"><div class="box1"></div><div style="clear: both;"></div>
</div>
  1. 给父元素添加 ::after 伪元素,再向元素添加一个空白的块元素,然后对其清除浮动,这样做和添加一个空的 div 的原理一样,可以达到相同的效果,而且不会在页面中添加多余的 div。
.clearfix {content: "";display: block;clear: both;
}

方法二: float + margin-left

.left {float: left;
}.right {margin-left: 100px;
}

二. position 定位

方法三: absolute + margin-left

.left {position: absolute;	/*开启定位脱离文档流*/
}.right {margin-left: 100px;
}

三. flex 布局

方法四:flex

.container {display: flex;
}.right {flex: 1;	/* flex-grow: 1; */
}

flex 是 flex-grow,flex-shrink,flex-basis 三个属性的简写形式。flex: 1 表示将三个属性值设置为 1 1 auto。

  • flex-grow:定义了 flex 子项如何分配多余的空间。默认值为0。值为 1 意味着该子项会等分多余的空间。
  • flex-shrink:定义了当空间不足时,flex 子项如何缩小。默认值为 1 ,意味着该子项会等比例缩小。
  • flex-basis:定义了 flex 子项的默认大小。默认值为 auto,意味着默认大小为内容大小。

.container {display: flex;
}
.left {flex: 1;
}
.right {flex: 4;
}

这种用法表示左列占容器宽度的 1/5,右列占 4/5,适用于左列不需要固定宽度值的情况。

四. grid 布局

方法五:grid

.container {dispaly: grid;grid-template-columns: 100px 1fr;
}

grid-template-columns: 100px 1fr; 表示左列宽度 100px,右列占据剩余空间。如果想要左列宽度根据内容大小自动调节,可设置为 grid-template-columns: auto 1fr;

这篇关于CSS:两列布局的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/685586

相关文章

CSS弹性布局常用设置方式

《CSS弹性布局常用设置方式》文章总结了CSS布局与样式的常用属性和技巧,包括视口单位、弹性盒子布局、浮动元素、背景和边框样式、文本和阴影效果、溢出隐藏、定位以及背景渐变等,通过这些技巧,可以实现复杂... 一、单位元素vm 1vm 为视口的1%vh 视口高的1%vmin 参照长边vmax 参照长边re

CSS3中使用flex和grid实现等高元素布局的示例代码

《CSS3中使用flex和grid实现等高元素布局的示例代码》:本文主要介绍了使用CSS3中的Flexbox和Grid布局实现等高元素布局的方法,通过简单的两列实现、每行放置3列以及全部代码的展示,展示了这两种布局方式的实现细节和效果,详细内容请阅读本文,希望能对你有所帮助... 过往的实现方法是使用浮动加

css渐变色背景|<gradient示例详解

《css渐变色背景|<gradient示例详解》CSS渐变是一种从一种颜色平滑过渡到另一种颜色的效果,可以作为元素的背景,它包括线性渐变、径向渐变和锥形渐变,本文介绍css渐变色背景|<gradien... 使用渐变色作为背景可以直接将渐China编程变色用作元素的背景,可以看做是一种特殊的背景图片。(是作为背

CSS自定义浏览器滚动条样式完整代码

《CSS自定义浏览器滚动条样式完整代码》:本文主要介绍了如何使用CSS自定义浏览器滚动条的样式,包括隐藏滚动条的角落、设置滚动条的基本样式、轨道样式和滑块样式,并提供了完整的CSS代码示例,通过这些技巧,你可以为你的网站添加个性化的滚动条样式,从而提升用户体验,详细内容请阅读本文,希望能对你有所帮助...

css实现图片旋转功能

《css实现图片旋转功能》:本文主要介绍了四种CSS变换效果:图片旋转90度、水平翻转、垂直翻转,并附带了相应的代码示例,详细内容请阅读本文,希望能对你有所帮助... 一 css实现图片旋转90度.icon{ -moz-transform:rotate(-90deg); -webkit-transfo

vue基于ElementUI动态设置表格高度的3种方法

《vue基于ElementUI动态设置表格高度的3种方法》ElementUI+vue动态设置表格高度的几种方法,抛砖引玉,还有其它方法动态设置表格高度,大家可以开动脑筋... 方法一、css + js的形式这个方法需要在表格外层设置一个div,原理是将表格的高度设置成外层div的高度,所以外层的div需要

Vue项目中Element UI组件未注册的问题原因及解决方法

《Vue项目中ElementUI组件未注册的问题原因及解决方法》在Vue项目中使用ElementUI组件库时,开发者可能会遇到一些常见问题,例如组件未正确注册导致的警告或错误,本文将详细探讨这些问题... 目录引言一、问题背景1.1 错误信息分析1.2 问题原因二、解决方法2.1 全局引入 Element

详解如何在React中执行条件渲染

《详解如何在React中执行条件渲染》在现代Web开发中,React作为一种流行的JavaScript库,为开发者提供了一种高效构建用户界面的方式,条件渲染是React中的一个关键概念,本文将深入探讨... 目录引言什么是条件渲染?基础示例使用逻辑与运算符(&&)使用条件语句列表中的条件渲染总结引言在现代

详解Vue如何使用xlsx库导出Excel文件

《详解Vue如何使用xlsx库导出Excel文件》第三方库xlsx提供了强大的功能来处理Excel文件,它可以简化导出Excel文件这个过程,本文将为大家详细介绍一下它的具体使用,需要的小伙伴可以了解... 目录1. 安装依赖2. 创建vue组件3. 解释代码在Vue.js项目中导出Excel文件,使用第三

Java实现Excel与HTML互转

《Java实现Excel与HTML互转》Excel是一种电子表格格式,而HTM则是一种用于创建网页的标记语言,虽然两者在用途上存在差异,但有时我们需要将数据从一种格式转换为另一种格式,下面我们就来看看... Excel是一种电子表格格式,广泛用于数据处理和分析,而HTM则是一种用于创建网页的标记语言。虽然两