CSS布局——水平垂直居中、等分布局、圣杯布局

简介: CSS布局——水平垂直居中、等分布局、圣杯布局

引言


信息时代,互联网是一个重要的信息传播载体。网页成为人们查找资源,获取信息,发布信息,学习交流的重要平台。现今世界,也是一个各项技术都飞速发展的时代。网页的设计制作依傍于互联网而生,并且风格设计在不断更新。因此,对网页的设计要求也不断提高,尤其是在创新的社会背景下网页设计的新理念和新方法,不断推陈出新。CSS对网页的布局是网页体系中的重中之重,本文基于此背景,阐述CSS+DIV技术在网页布局方面的应用。


1 CSS盒子模型


CSS盒子模型是网页布局的核心,所有的HTML元素都可以看作是盒子,CSS盒子模型本质上是一个盒子封装周围的HTML元素。盒子模型主要有四种属性:边距(margin)、边界(border)、边框距(padding)和内容(content)。

image.png


1.1水平垂直居中


水平垂直居中顾名思义就是将行内元素在水平和垂直两个方向居中对齐。利用flex来居中布局是非常好的一种方式,几行代码就能优雅的实现元素水平垂直完美居中。使用flex来居中首先我们要了解什么是flex布局,flex布局通常被称为flexible box(弹性布局),是一种一维的布局模型。它给flex的子元素提供强大的空间分布和对齐能力。而采用flex布局的元素叫做容器,在flex布局中的子元素被称为项目(即父级元素采用flex布局,则父级元素为容器,全部子元素自动成为项目);在容器中默认有水平的主轴和垂直的交叉轴,项目在容器中默认沿主轴排列。Flex常用属性有六个:flex-direction、flex-wrap、flex-flow、justify-content、align-items、align-content。

如果想实现水平垂直居中的效果,CSS代码设置如下:

.box {
background-color: #FF8C00;
width: 300px;
height: 300px;
display: flex;
justify-content: center;
align-items: center;
}
.content {
background-color: #F0000;
width: 100px;
height: 100px;
    }


CSS代码设置父元素背景颜色为橙色,宽度和高度为300px;设置子元素背景颜色为红色,

align-items属性定义了项目在交叉轴上是如何对其的,既使子元素垂直居中;justify-content属性使子元素水平居中。需要注意的是一定要给父元素添加display:flex;这是开启flex布局的钥匙。

image.png


1.2等分布局


等分布局就是将一行分为多列,每一列的宽度是相同的。使用float + padding + background-clip布局的方式。padding 简写属性在一个声明中设置所有填充属性,该属性可以有1到4个值;background-clip属性指定背景绘制区域。即用padding来实现子元素之间的间距,使用background-clip使子元素padding部分不显示背景。

如果想实现等分布局的效果,CSS代码设置如下:

.parentWrap {
border: 2pxsolidblack;
overflow: hidden;
}
.parent {
background-color: lightgrey;
margin-right: -10px;
overflow: hidden;
}
.child {
float: left;
height: 300px;
width: 25%;
padding-right: 10px;
box-sizing: border-box;
background-clip: content-box;
}


子元素中float为设置浮动类型,left为向左浮动;height设置高度;本行分为四列,所以宽度为25%,padding-right是设置一个元素的右填充在此填充了10px,即每个子元素之间的空隙。


image.png


1.3圣杯布局


圣杯布局是header和footer各占领屏幕所有宽度,高度固定;中间的container是一个三栏布局;三栏布局两侧宽度是固定不变的中间部分自动填充整个区域;中间的部分是三栏中高度最高的部分。实现圣杯布局效果也可以采用flex布局,就是一个大盒子包含三个子盒子,左右两个盒子固定宽高,中间盒子设置flex:1(占据大盒子剩余空间)。

如果想实现圣杯布局的效果,CSS代码设置如下:

body {
min-width: 550px;  
font-weight: bold;
font-size: 20px;
  }
#header, #footer {
background: rgba(29, 27, 27, 0.726);
text-align: center;
height: 60px;
line-height: 60px;
  }
#container {
display: flex;
  }
#container .column {
text-align: center;
height: 300px;
line-height: 300px;
  }
#center {
flex: 1;
background: rgb(206, 201, 201);
  }
#left {
width: 200px;        
background: rgba(95, 179, 235, 0.972);
  }
#right {
width: 200px;           
background: rgb(231, 105, 2);
  }


Header和footer部分高度设置为60px,文本元素设置为排列居中高度为60px;中间部分center设置属性为flex:1该部分空间大小可以改变,left和right部分宽度设置为200px。

image.png


结语


DIV+CSS布局是网页开发的重要部分,它将整个网页分割成多个块使整体变得整齐有序,“DIV+CSS”盒子模型代码实现也相对简单,逻辑清楚,非常适合平时使用。本文只是简单列举了单列布局、双列布局和三列布局布局设计。如果想要搭建一个好看完整的网页还需要很多的技术支持,这就需要不断地学习探索。

目录
相关文章
|
2月前
|
前端开发 UED 容器
在 CSS 中使用 Flex 布局实现页面自适应时需要注意什么?
【10月更文挑战第22天】在使用 Flex 布局实现页面自适应时,需要对其基本原理和特性有深入的理解,同时结合具体的布局需求和场景,进行细致的调整和优化。通过合理的设置和注意事项的把握,才能实现理想的自适应效果,提升用户体验。还可以根据实际情况进行更深入的探索和实践,以不断提升 Flex 布局的应用能力。
|
2月前
|
前端开发 JavaScript 开发者
掌握 CSS 弹性布局(Flexbox):构建复杂页面布局的高效秘籍与实战案例
CSS弹性布局(Flexbox)是现代网页设计中构建复杂页面布局的高效工具。本文将深入浅出地介绍Flexbox的核心概念、使用技巧及实际应用案例,帮助读者快速掌握这一强大布局方法。
|
3月前
|
前端开发 容器
使用 CSS Grid 布局实现响应式设计
【10月更文挑战第1天】使用 CSS Grid 布局实现响应式设计
75 4
|
3月前
|
前端开发 容器
前端技术分享:利用CSS Grid布局实现响应式设计
【10月更文挑战第1天】前端技术分享:利用CSS Grid布局实现响应式设计
|
2月前
|
前端开发 容器
实现CSS品字布局
【10月更文挑战第27天】
|
4月前
|
JavaScript 前端开发
网页前端课程设计-【模仿】香港中文大学官网,轮播图及div+css布局,js的dom操作
这篇文章介绍了如何模仿香港中文大学官网进行网页前端课程设计,包括使用div+css布局、js的DOM操作以及实现轮播图等技术细节。
|
8月前
|
Web App开发 XML 前端开发
CSS中的非布局样式+CSS布局 前端开发入门笔记(十一)
CSS中的非布局样式+CSS布局 前端开发入门笔记(十一)
87 0
|
前端开发
网站开发之DIV+CSS简单布局网站入门篇(五)
这篇文章主要介绍如何使用DIV和CSS简单布局一个网站的首页,通常将网站划分为顶部(Logo、导航条)、中部(页面主要内容、左右栏目)、底部(制作方介绍、超链接)。这是非常基础的一篇引入性文章,采用案例的方式进行介绍的,希望对你有所帮助。运行结果如下图所示:main.html主页面代码:主要通过di
3646 0
|
前端开发 容器 JavaScript
CSS Grid布局入门
相信大家都比较熟悉flex布局了,最近有空研究了波grid布局,感觉虽然兼容性还不是太高,应用不是太普遍,但是功能非常强大。未来应该是grid+flex为主流,grid是二维布局,很灵活,适合整体构架,而flex是一维布局,适合处理局部细节。
1190 0