HTML的三种布局:DIV+CSS、FLEX、GRID
Div+css布局
也就是盒子模型,有W3C盒子模型,IE盒子模型。盒子模型由四部分组成margin、border、padding、content。
怎么区别这两种模型呢,区别在于w3c中的width是content的宽,IE的width是content+border+padding。
具体的可以看下面的图:
W3C盒子(标准盒子):

IE盒子:

Flex弹性布局
通过使用display:flex;或者display:inline-flex;坏处就是不能再设置子元素的float、clear、vertical-align。
在这里面主要是在元素里建立主轴(main axis、横向的、水平的),交叉轴(cross axis、垂直的,竖向的)。主轴从左到右,左是main start,右是main end,之间是main size。交叉轴是从上到下,上是cross start,下是cross end,之间是cross size。
如图所示:

就用这个为例子嘛:
<div class="box">
<p class="item">1</p>
<p class="item">2</p>
</div>
在父元素div.box中可以设置的属性有六个:
1.flex-direction:row | row-reverse | column | column-reverse;
解释:这个主要用于设置子元素的排列顺序。row表示横向排列,从左到右;row-reverse表示横向排列,从右到左;column表示竖向排列,从上到下;column-reverse表示竖向排列,从下到上。
2.flex-warp:nowarp | warp | warp-reverse;
解释:设置元素的换行,nowarp表示不换行;warp表示换行,按一般的规律换到下面去;warp-reverse表示换行,不过换行是换到这一行的上面去。
3.flex-flow
解释:他是flex-direction和flex-warp的简写,默认值是row,nowarp。
4.justify-content: flex-start | center | flex-end | space-between | space-around ;
解释:元素在主轴上的对齐方式。 flex-start左对齐;center居中;flex-end右对齐;space-between两端对齐;space-around四周对齐。
5.align-items: flex-start | center | flex-end | baseline | stretch ;
解释:元素在交叉轴上的对齐方式。flex-start上对齐;center居中对齐; flex-end下对齐;baseline文字基线对齐;stretch没有高度或高度为auto时自动充满高度。
6.align-content:flex-start | center | flex-end | space-between | space-around | stretch;
解释:主轴和交叉轴同时出现时的对齐方式。flex-start左上角对齐;center中间对齐;flex-end右下角对齐;space-between两端对齐,轴线之间平均分布;space-around每根轴线两侧间隔线相等;stretch沿交叉轴方向填充。
子元素(div.item)的六个属性:
1.order:number ;
解释:设置元素的排列顺序,数值越小越靠前,默认为0。
2.flex-grow:number;
解释:元素放大的比例,默认为0.
3.flex-shrink:number;
解释:元素缩小比例,默认为1;
4.flex-basis:length | auto;
解释:元素占据的固定空间,默认auto。
5.flex:none| auto | 其他值;
解释:flex-grow、flex-shrink、flex-basis的简写,默认值为0,1,auto。none表示(0,0,auto),auto表示(1,1,auto)。
6.align-self:auto | flex-start | center | flex-end | baseline | baseline | stretch;
解释:允许单个元素与其他元素不一样的对齐方式,可覆盖align-items属性,默认值为auto,表示基础呢个父元素的align-items若无父元素,则等同于stretch。
我贴一个我自己的例子嘛:(主要是通过写骰子里面的圆点的位置来练习的)
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<style>
/*基本的元素样子*/
.box{
width: 300px;
height: 300px;
border: 1px solid red;
margin: 15px auto;
background-color: gainsboro;
}
.item{
background-color: fuchsia;
width: 60px;
height: 60px;
border-radius: 30px;
margin: 15px;
border: 1px solid black;
text-align: center;
line-height: 60px;
font-size: 18px;
}
</style>
</head>
<body>
<div class="box">
<p class="item">1</p>
<p class="item">2</p>
</div>
<!--flex样式-->
<style>
.box{
display:flex;
}
/*1*/
/*.box{
display:flex;
}*/
/*2*/
/*.box{
justify-content: center;
}*/
/*3*/
/*.box{
justify-content: flex-end;
}*/
/*4*/
/*.box{
align-items: center;
}*/
/*5*/
/*.box{
justify-content: center;
}
.item{
align-self: center;
}*/
/*或者*/
/*.box{
justify-content: center;
align-items: center;
}*/
/*6*/
/*.box{
justify-content: flex-end;
align-items: center;
}*/
/*7*/
/*.box{
align-items: flex-end;
}*/
/*8*/
/*.box{
justify-content: center;
align-items: flex-end;
}*/
/*9*/
/*.box{
justify-content: flex-end;
align-items: flex-end;
}*/
/*12*/
/*13*/
/*.box{
flex-direction: row;
justify-content: space-between;
}*/
/*14*/
/*.box{
flex-direction: column;
}*/
/*15*/
/*.box{}
.item:nth-child(2){
align-self: center;
}*/
/*16*/
/*.box{
flex-direction: row;
align-items: center;
justify-content: space-between;
}
.item:nth-child(1){
align-self: flex-start;
}*/
/*17*/
/*.box{
flex-direction: column;
align-content: space-between;
}*/
/*18*/
/*.box{
align-items: center;
}
.item:nth-child(1){
align-self: flex-start;
}
.item:nth-child(2){
align-self: flex-end;
}*/
/*或者*/
/*.box{
align-items: flex-end;
}
.item:nth-child(1){
align-self: flex-start;
}*/
/*19*/
/*.box{
justify-content: space-between;
}
.item:nth-child(2){
align-self: flex-end;
}*/
</style>
</body>
</html>
Grid网格布局
通过display:grid;或者display:inline-grid;网格线将元素分成一个一个的小格子。

如图,每一条线都是网格线,水平的网格线从上到下一次是网格线1、网格线2、网格线3;垂直的网格线是网格线1、网格线2、网格线3、网格线4。
给元素划分网格父元素会使用到如下的属性:
1.grid-temlate-columns:number/perecent;划分列。可以有多个值(可以是具体的100px也可以是百分比),每一个值代表一列。
2.grin-template-rows:number/percent;划分行。与划分列的规则一样。
子元素可以独占一个网格也可以占多个网格,属性设置如下:
1.grid-columns-start:number;元素从哪个网格线列开始。
2.grid-columns-end:number;元素到哪个网格线列结束。
3.grid-row-start:元素从哪个网格线行开始;
4.grid-row-end:元素从哪个网格行结束;
1~4这几个属性就相当于设置元素的跨几行、跨几列这样。
下面是我自己写的例子,仅供参考哦:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<style>
.warpper{
display: grid;
border: 3px solid aquamarine;
text-align: center;
grid-template-columns: 100px 100px 100px;
grid-template-rows: 100px 100px 100px;
}
div:nth-child(1) {
background-color: firebrick;
}
div:nth-child(2) {
background-color: forestgreen;
}
div:nth-child(3) {
background-color: fuchsia;
}
div:nth-child(4) {
background-color: cornflowerblue;
}
div:nth-child(5) {
background-color: gold;
}
div:nth-child(6) {
background-color: greenyellow;
}
.item1{
grid-column-start: 1;
grid-column-end: 3;
}
.item3{
grid-row-start: 2;
grid-row-end: 4;
}
.item4{
grid-column-start: 2;
grid-column-end: 4;
}
</style>
</head>
<body>
<div class="warpper">
<div class="item1">1</div>
<div class="item2">2</div>
<div class="item3">3</div>
<div class="item4">4</div>
<div class="item5">5</div>
<div class="item6">6</div>
</div>
</body>
</html>
以上就是我自己对与HTML中的三种布局的认识,有不足的地方还请各位帮我指出来,这样下次就会多加注意啦!!!谢谢
我想我应该把我自己参考学习的博客贴出来的,可是不知道怎么弄,我再研究下,这样下一篇就可以贴出来
HTML的三种布局:DIV+CSS、FLEX、GRID的更多相关文章
- CSS三种布局模型是什么?
在网页中,元素有三种布局模型:流动模型(Flow) 默认的.浮动模型 (Float).层模型(Layer).下面我们来看一下这三种布局模型. 三种布局模型介绍: 1.流动模型(Flow) 流动(Flo ...
- JavaGUI三种布局管理器FlowLayout,BorderLayout,GridLayout的使用
三种布局管理器 流式布局FlowLayout package GUI; import java.awt.*; import java.awt.event.WindowAdapter; import j ...
- 三种方法实现CSS三栏布局
本文由云+社区发表 作者:前端林子 本文会分别介绍三种CSS实现三栏布局的方法,可在浏览器中打开查看效果 1.方法一:自身浮动的方法 实现方法:需要左栏向左浮动,右栏向右浮动,中间设左右margin来 ...
- HTML中放置CSS的三种方式和CSS选择器
(一)在HTML中使用CSS样式的方式一般有三种: 1 内联引用 2 内部引用 3 外部引用. 第一种:内联引用(也叫行内引用) 就是把CSS样式直接作用在HTML标签中. <p style ...
- HTML布局四剑客-Flex,Grid,Table,Float
前言 在HTML布局中有很多的选择,同一种表现方式可以使用不同的方法来实现.下面来对四种最常见的布局方式进行阐述和解释,它们分别是Float,Table,Grid和Flex Float 第一位出场的就 ...
- css三种布局方式
第一种布局方式:标准流(文档流) 标准流即为元素默认的显示方式.如块级元素独占一行,行内元素可以在一行显示. 第二种布局方式:浮动,float属性 浮动对应的css属性是float:left/righ ...
- 【Android学习】三种布局<include />、<merge />、<ViewStub />
1.布局重用<include /> <include />标签能够重用布局文件,使用起来非常简单 <include layout="@layout/layout ...
- Python连载61-tkinter三种布局
一.pack布局举例 #pack布局案例 import tkinter baseFrame = tkinter.Tk() #以下代码都是创建一个组件,然后布局 btn1 = tkinter.Butto ...
- css之页面三列布局
左右两边宽度固定,中间自适应 第一种方法:左右两边绝对定位 html代码 <div class="left"></div> <div class=&q ...
随机推荐
- 《java.util.concurrent 包源码阅读》20 DelayQueue
DelayQueue有序存储Delayed类型或者子类型的对象,没当从队列中取走元素时,需要等待延迟耗完才会返回该对象. 所谓Delayed类型,因为需要比较,所以继承了Comparable接口: p ...
- 对于String 与StringBuffer 和StringBuilder的总结
StringBuffer 1,线程安全的可变字符序列.一个类似于 String 的字符串缓冲区,但不能修改 2,虽然在任意时间点上它都包含某种特定的字符序列,但通过某些方法调用可以改变该序列的长度 ...
- c语言的字符串
1. 字符串 1. 什么是字符串 ● 简单的字符串”itcast” ● 一个’i’是一个字符 ● 很多个字符组合在一起就是字符串了 2. 字符串的初始化 ● char a[] = “123”; ...
- 乐呵乐呵得了 golang入坑系列
开场就有料,今天返回去看了看以前的文章,轻松指数有点下降趋势.一琢磨,这不是我的风格呀.一反思,合着是这段时间,脑子里杂七杂八的杂事有点多,事情一多,就忘了快乐.古话说得好:愁也一天,乐也一天,只要还 ...
- 在C#中输出变量的地址
int a = 3; GCHandle handle = GCHandle.Alloc(a); var pin = GCHandle.ToIntPtr(handle); Console.WriteLi ...
- C# 中枚举的一点研究(跳过一些net坑的研究而已)
之前一直使用Enum.Parse()将字符串转为枚举,没有深究,后面发现一个问题后对下面的Enum有了一个初步研究(.net 4.0).看下面代码. (留意,枚举类型是值类型,其值不能为Null,所以 ...
- MySQL学习——基本命令(1)
MySQL添加新用户.为用户创建数据库.为新用户分配权限 参考博客http://blog.csdn.net/u013216667/article/details/70158452 一.登录MySQL ...
- NYOJ 2357: 插塔憋憋乐 贪心
2357: 插塔憋憋乐 时间限制: 1 Sec 内存限制: 128 MB 提交: 82 解决: 18 [提交][状态][讨论版] 题目描述 众所不知,LLM是一位红警3大佬,打的非常厉害,但是曾经 ...
- SQLServer复习文档1(with C#)
目录: 前言 SQL Server基础准备 1.新建数据库 2.在数据中添加表 3.向表中添加数据 SQL Server与C#基础准备 实例解析 1.C#连接数据库 2.查询特定列数据 3.使用列别名 ...
- ElasticSearch 学习记录之ES短语匹配基本用法
短语匹配 短语匹配故名思意就是对分词后的短语就是匹配,而不是仅仅对单独的单词进行匹配 下面就是根据下面的脚本例子来看整个短语匹配的有哪些作用和优点 GET /my_index/my_type/_sea ...