在CSS中,"box model"这一术语是用来设计和布局时使用,而后在网页中基本上都会显示一些方方正正的盒子。咱们称为这种盒子叫盒模型。css
盒模型有两种:标准模型和IE模型。咱们在这里重点讲标准模型。html
width:内容的宽度前端
height: 内容的高度python
padding:内边距,边框到内容的距离linux
border: 边框,就是指的盒子的宽度web
margin:外边距,盒子边框到附近最近盒子的距离浏览器
若是让你作一个宽高402*402的盒子,您如何来设计呢?布局
答案有上万种,甚至上一种。学习
若是一个盒子设置了padding,border,width,height,margin(我们先不要设置margin,margin有坑,后面课程会讲解)spa
盒子的真实宽度=width+2*padding+2*border
盒子的真实宽度=height+2*padding+2*border
那么在这里要注意看了。标准盒模型,width不等于盒子真实的宽度。
另外若是要保持盒子真实的宽度,那么加padding就必定要减width,减padding就必定要加width。真实高度同样设置。
**************************************************************************************************************************
padding:就是内边距的意思,它是边框到内容之间的距离
另外padding的区域是有背景颜色的。而且背景颜色和内容的颜色同样。也就是说background-color这个属性将填充全部的border之内的区域
padding有四个方向,分别描述4个方向的padding。
描述的方法有两种
一、写小属性,分别设置不一样方向的padding
padding-top: 30px; padding-right: 30px; padding-bottom: 30px; padding-left: 30px;
二、写综合属性,用空格隔开
/*上 右 下 左*/ padding: 20px 30px 40px 50px ; /*上 左右 下*/ padding: 20px 30px 40px; /* 上下 左右*/ padding: 20px 30px; /*上下左右*/ padding: 20px;
好比ul标签,有默认的padding-left值。
那么咱们通常在作站的时候,是要清除页面标签中默认的padding和margin。以便于咱们更好的去调整元素的位置。
咱们如今初学可使用通配符选择器
*{ padding:0; margin:0; }
But,这种方法效率不高。
因此咱们要使用并集选择器来选中页面中应有的标签(不一样背,由于有人已经给我们写好了这些清除默认的样式表,reset.css)
https://meyerweb.com/eric/tools/css/reset/
*************************************************************************************************************************
border(边框)
border:边框的意思,描述盒子的边框
边框有三个要素: 粗细 线性样式 颜色
border: solid
若是颜色不写,默认是黑色。若是粗细不写,不显示边框。若是只写线性样式,默认的有上下左右 3px的宽度,实体样式,而且黑色的边框。
border-width: 3px; border-style: solid; border-color: red; /* border-width: 5px 10px; border-style: solid dotted double dashed; border-color: red green yellow;
border-top-width: 10px; border-top-color: red; border-top-style: solid; border-right-width: 10px; border-right-color: red; border-right-style: solid; border-bottom-width: 10px; border-bottom-color: red; border-bottom-style: solid; border-left-width: 10px; border-left-color: red; border-left-style:solid;
上面12条语句,至关于 bordr: 10px solid red;
另外还能够这样
border-top: 10px solid red; border-right: 10px solid red; border-bottom: 10px solid red; border-left: 10pxb solid red;
border:none;
border:0;
表示border没有设置样式。
/*小三角 箭头指向下方*/ div{ width: 0; height: 0; border-bottom: 20px solid red; border-left: 20px solid transparent; border-right: 20px solid transparent; }
margin:外边距的意思。表示边框到最近盒子的距离.
/*表示四个方向的外边距离为20px*/ margin: 20px; /*表示盒子向下移动了30px*/ margin-top: 30px; /*表示盒子向右移动了50px*/ margin-left: 50px; margin-bottom: 100px;
**********************************************************************************************
标准文档流
宏观的将,咱们的web页面和ps等设计软件有本质的区别,web 网页的制做,是个“流”,从上而下 ,像 “织毛衣”。而设计软件 ,想往哪里画东西,就去哪里画
标准文档流下 有哪些微观现象?
多个空格会被合并成一个空格显示到浏览器页面中。img标签换行写。会发现每张图片之间有间隙,若是在一行内写img标签,就解决了这个问题,可是咱们不会这样去写咱们的html结构。这种现象称为空白折叠现象。
文字还有图片大小不一,都会让咱们页面的元素出现高矮不齐的现象,可是在浏览器查看咱们的页面总会发现底边对齐
若是在一行内写文字,文字过多,那么浏览器会自动换行去显示咱们的文字。
**************************************************************************************************************************
块级元素和行内元素
学习的初期,咱们就要知道,标准文档流等级森严。标签分为两种等级:
好比h1标签和span,同时设置宽高,来看浏览器效果,那么你会发现:
行内元素和块级元素的区别:(很是重要)
行内元素:
块级元素:
块级元素和行内元素的分类:
在之前的HTML知识中,咱们已经将标签分过类,当时分为了:文本级、容器级。
从HTML的角度来说,标签分为:
PS:为甚么说p是文本级标签呢?由于p里面只能放文字&图片&表单元素,p里面不能放h和ul,p里面也不能放p。
如今,从CSS的角度讲,CSS的分类和上面的很像,就p不同:
行内元素:除了p以外,全部的文本级标签,都是行内元素。p是个文本级,可是是个块级元素。
块级元素:全部的容器级标签都是块级元素,还有p标签。
咱们能够经过display
属性将块级元素和行内元素进行相互转换。display即“显示模式”。
一旦,给一个块级元素(好比div)设置:
display: inline;
那么,这个标签将当即变为行内元素,此时它和一个span无异。inline就是“行内”。也就是说:
一样的道理,一旦给一个行内元素(好比span)设置:
display: block;
那么,这个标签将当即变为块级元素,此时它和一个div无异。block”是“块”的意思。也就是说:
标准流里面的限制很是多,致使不少页面效果没法实现。若是咱们如今就要并排、而且就要设置宽高,那该怎么办呢?办法是:移民!脱离标准流!
css中一共有三种手段,使一个元素脱离标准文档流:
**************************************************************************************************************************
浮动是css里面布局最多的一个属性,也是很重要的一个属性。
float:表示浮动的意思。它有四个值。
看一个例子
html结构:
<div class="box1"></div> <div class="box2"></div> <span>路飞学城</span>
css样式:
.box1{ width: 300px; height: 300px; background-color: red; float:left; } .box2{ width: 400px; height: 400px; background-color: green; float:right; } span{ float: left; width: 100px; height: 200px; background-color: yellow; }
咱们会发现,三个元素并排显示,.box1和span由于是左浮动,紧挨在一块儿,这种现象贴边。.box2盒子由于右浮动,因此紧靠着右边。
那么浮动若是你们想学好,必定要知道它的四大特性
1.浮动的元素脱标
2.浮动的元素互相贴靠
3.浮动的元素由"子围"效果
4.收缩的效果
脱标:就是脱离了标准文档流
看例子
<div class="box1">小红</div> <div class="box2">小黄</div> <span>小马哥</span> <span>小马哥</span>
.box1{ width: 200px; height: 200px; background-color: red; float: left; } .box2{ width: 400px; height: 400px; background-color: yellow; } span{ background-color: green; float: left; width: 300px; height: 50px; }
效果:红色盒子压盖住了黄色的盒子,一个行内的span标签居然可以设置宽高了。
缘由1:小红设置了浮动,小黄没有设置浮动,小红脱离了标准文档流,其实就是它不在页面中占位置了,此时浏览器认为小黄是标准文档流中的第一个盒子。因此就渲染到了页面中的第一个位置上。这种现象,也有一种叫法,浮动元素“飘起来了”,但我不建议你们这样叫。
缘由2:全部的标签一旦设置浮动,就可以并排,而且都不区分行内、块状元素,都可以设置宽高
看例子
html结构
<div class="box1">1</div> <div class="box2">2</div> <div class="box3">3</div>
css样式
.box1{ width: 100px; height: 400px; float: left; background-color: red; } .box2{ width: 150px; height: 450px; float: left; background-color: yellow; } .box3{ width: 300px; height: 300px; float: left; background-color: green; }
效果发现:
若是父元素有足够的空间,那么3哥紧靠着2哥,2哥紧靠着1哥,1哥靠着边。
若是没有足够的空间,那么就会靠着1哥,若是再没有足够的空间靠着1哥,本身往边靠
html结构:
<div> <img src="./images/企业1.png" alt=""> </div> <p> 这里面放超多东西 </p>
css样式:
*{ padding: 0; margin: 0; } div{ float: left; } p{ background-color: #666; }
效果发现:所谓字围效果,当div浮动,p不浮动,div遮盖住了p,div的层级提升,可是p中的文字不会被遮盖,此时就造成了字围效果。
收缩:一个浮动元素。若是没有设置width,那么就自动收缩为文字的宽度(这点跟行内元素很像)
html结构:
<div> alex </div>
css样式:
div{ float: left; background-color: red; }
你们必定要谨记:关于浮动,咱们初期必定要遵循一个原则,永远不是一个盒子单独浮动,要浮动就要一块儿浮动。另外,有浮动,必定要清除浮动,
在页面布局的时候,每一个结构中的父元素的高度,咱们通常不会设置。(为何?)
你们想,若是我初版的页面的写完了,感受很是爽,忽然隔了一个月,老板说页面某一块的区域,我要加点内容,或者我以为图片要缩小一下。这样的需求在工做中很是常见的。真想打他啊。那么此时做为一个前端小白,确定是去每一个地方加内容,改图片,而后修改父盒子的高度。那问题来了,这样不影响开发效率吗?答案是确定的。
看一个效果:
html效果:
<div class="father"> <div class="box1"></div> <div class="box2"></div> <div class="box3"></div> </div> <div class="father2"></div>
css样式:
*{ padding: 0; margin: 0; } .father{ width: 1126px; /*子元素浮动 父盒子通常不设置高度*/ /*出现这种问题,咱们要清除浮动带来影响*/ /*height: 300px;*/ } .box1{ width: 200px; height: 500px; float: left; background-color: red; } .box2{ width: 300px; height: 200px; float: left; background-color: green; } .box3{ width: 400px; float: left; height: 100px; background-color: blue; } .father2{ width: 1126px; height: 600px; background-color: purple; }
效果发现:若是不给父盒子一个高度,那么浮动子元素是不会填充父盒子的高度,那么此时.father2的盒子就会跑到第一个位置上,影响页面布局。
那么咱们知道,浮动元素确实能实现咱们页面元素并排的效果,这是它的好处,同时它还带来了页面布局极大的错乱!!!因此咱们要清除浮动
还好还好。咱们有多种清除浮动的方法,在这里给你们介绍四种:
这个方法给你们上个代码介绍,它的使用不灵活,通常会经常使用页面中固定高度的,而且子元素并排显示的布局。好比:导航栏
clear:意思就是清除的意思。
有三个值:
left:当前元素左边不容许有浮动元素
right:当前元素右边不容许有浮动元素
both:当前元素左右两边不容许有浮动元素
给浮动元素的后面加一个空的div,而且该元素不浮动,而后设置clear:both。
html结构:
<div> <ul> <li>Python</li> <li>web</li> <li>linux</li> <!-- 给浮动元素最后面加一个空的div 而且该元素不浮动 ,而后设置clear:both 清除别人对个人浮动影响--> <!-- 内墙法 --> <!-- 平白无故加了div元素 结构冗余 --> <div class="clear"></div> </ul> </div> <div class="box"> </div>
css样式
*{ padding: 0; margin: 0; } ul{ list-style: none; } div{ width: 400px; } div ul li { float: left; width: 100px; height: 40px; background-color: red; } .box{ width: 200px; height: 100px; background-color: yellow; } .clear{ clear: both; }
给浮动子元素的父盒子,也就是不浮动元素,添加一个clearfix的类,而后设置
.clearfix:after{ /*必需要写这三句话*/ content: '.'; clear: both; display: block; }
新浪首页推荐伪元素清除法的写法
/*新浪首页清除浮动伪元素方法*/ content: "."; display: block; height: 0; clear: both; visibility: hidden
overflow属性规定当内容溢出元素框时发生的事情。
说明:
这个属性定义溢出元素内容区的内容会如何处理。若是值为 scroll,不管是否须要,用户代理都会提供一种滚动机制。所以,有可能即便元素框中能够放下全部内容也会出现滚动条。
有五个值:
值 | 描述 |
---|---|
visible | 默认值。内容不会被修剪,会呈如今元素框以外。 |
hidden | 内容会被修剪,而且其他内容是不可见的。 |
scroll | 内容会被修剪,可是浏览器会显示滚动条以便查看其他的内容。 |
auto | 若是内容被修剪,则浏览器会显示滚动条以便查看其他的内容。 |
inherit | 规定应该从父元素继承 overflow 属性的值。 |
逐渐演变成overflow:hidden清除法。
其实它是一个BFC区域: http://www.javashuo.com/article/p-ezyacvwn-v.html
到此为止。关于浮动的实现并排、清除浮动的四个用法已经介绍完毕,你们必定要熟记于心。
当时说到了盒模型,盒模型包含着margin,为何要在这里说margin呢?由于元素和元素在垂直方向上margin里面有坑。
咱们来看一个例子:
html结构:
<div class="father"> <div class="box1"></div> <div class="box2"></div> </div>
css样式:
*{ padding: 0; margin: 0; } .father{ width: 400px; overflow: hidden; border: 1px solid gray; } .box1{ width: 300px; height: 200px; background-color: red; margin-bottom: 20px;} .box2{ width: 400px; height: 300px; background-color: green; margin-top: 50px; }
当给两个标准流下兄弟盒子 设置垂直方向上的margin时,那么以较大的为准,那么咱们称这种现象叫塌陷。无法解决,咱们称为这种技巧叫“奇淫技巧”。记住这种现象,在布局垂直方向盒子的时候主要margin的用法。
当咱们给两个标准流下的兄弟盒子设置浮动以后,就不会出现margin塌陷的问题。
div{ width: 780px; height: 50px; background-color: red; /*水平居中盒子*/ margin: 0px auto; /*水平居中文字*/ text-align: center; }
当一个div元素设置margin:0 auto;时就会居中盒子,那咱们知道margin:0 auto;表示上下外边距离为0,左右为auto的距离,那么auto是什么意思呢?
设置margin-left:auto;咱们发现盒子尽量大的右边有很大的距离,没有什么意义。当设置margin-right:auto;咱们发现盒子尽量大的左边有很大的距离。当两条语句并存的时候,咱们发现盒子尽量大的左右两边有很大的距离。此时咱们就发现盒子居中了。
另外如何给盒子设置浮动,那么margin:0 auto失效。
使用margin:0 auto;注意点:
1.使用margin: 0 auto;水平居中盒子必须有width,要有明确width,文字水平居中使用text-align: center;
2.只有标准流下的盒子 才能使用margin:0 auto;
当一个盒子浮动了,固定定位,绝对定位(后面会讲),margin:0 auto; 不能用了
3.margin:0 auto;居中盒子。而不是居中文本,文字水平居中使用text-align: center;
另外你们必定要知道margin属性是描述兄弟盒子的关系,而padding描述的是父子盒子的关系
若是让你们实现如图的效果,应该有很多的同窗作不出来。
那么咱们来看看这个案例,它的坑在哪里?
下面这个代码应该是你们都会去写的代码。
*{ padding: 0; margin: 0; } .father{ width: 300px; height: 300px; background-color: blue; } .xiongda{ width: 100px; height: 100px; background-color: orange; margin-top: 30px; }
由于父亲没有border,那么儿子margin-top实际上踹的是“流” 踹的是行,因此父亲掉下来了,一旦给父亲一个border发现就行了。
那么问题来了,咱们不可能在页面中平白无故的去给盒子加一个border,因此此时的解决方案只有一种。就是使用父亲的padding。让子盒子挤下来。