在CSS中,html中的标签元素大致被分为三种不一样的类型:块状元素、内联元素(又叫行内元素)和内联块状元素。html
经常使用的块状元素有:
<div>、<p>、<h1>...<h6>、<ol>、<ul>、<dl>、<table>、<address>、<blockquote> 、<form>
经常使用的内联元素有:
<a>、<span>、<br>、<i>、<em>、<strong>、<label>、<q>、<var>、<cite>、<code>
经常使用的内联块状元素有:<img>、<input>浏览器
1、块状元素特色布局
一、每一个块级元素都重新的一行开始,而且其后的元素也另起一行。spa
二、元素的高度、宽度、行高以及顶和底边距均可设置。设计
三、元素宽度在不设置的状况下,是它自己父容器的100%(和父元素的宽度一致),除非设定一个宽度。code
将内联元素a转换为块状元素,a{display:block;}
2、内联元素特色orm
一、和其余元素都在一行上;htm
二、元素的高度、宽度及顶部和底部边距不可设置;图片
三、元素的宽度就是它包含的文字或图片的宽度,不可改变。ci
块状元素div转换为内联元素 div{ display:inline; }
3、内联块状元素特色
一、和其余元素都在一行上;
二、元素的高度、宽度、行高以及顶和底边距均可设置。
4、盒子模型
布局模型
在网页中,元素有三种布局模型:
一、流动模型(Flow)
二、浮动模型 (Float)
三、层模型(Layer)
流动模型
流动(Flow)是默认的网页布局模式。
第二点,在流动模型下,内联元素都会在所处的包含元素内从左到右水平分布显示。(内联元素可不像块状元素这么霸道独占一行)。
浮动模型
块状元素这么霸道都是独占一行,若是如今咱们想让两个块状元素并排显示,怎么办呢?不要着急,设置元素浮动就能够实现这一愿望。任何元素在默认状况下是不能浮动的,但能够用 CSS 定义为浮动,如 div、p、table、img 等元素均可以被定义为浮动。以下代码能够实现两个 div 元素一行显示。
div{ width:200px; height:200px; border:2px red solid; float:left; } <div id="div1"></div> <div id="div2"></div>
什么是层布局模型?
层布局模型就像是图像软件PhotoShop中很是流行的图层编辑功能同样,每一个图层可以精肯定位操做,但在网页设计领域,因为网页大小的活动性,层布局没能受到热捧。可是在网页上局部使用层布局仍是有其方便之处的。
如何让html元素在网页中精肯定位,就像图像软件PhotoShop中的图层同样能够对每一个图层可以精肯定位操做。CSS定义了一组定位(positioning)属性来支持层布局模型。
层模型有三种形式:
一、绝对定位(position: absolute)
二、相对定位(position: relative)
三、固定定位(position: fixed)
绝对定位:若是想为元素设置层模型中的绝对定位,须要设置position:absolute(表示绝对定位),这条语句的做用将元素从文档流中拖出来,而后使用left、right、top、bottom属性相对于其最接近的一个具备定位属性的父包含块进行绝对定位。若是不存在这样的包含块,则相对于body元素,即相对于浏览器窗口。
相对定位:须要设置position:relative(表示相对定位),它经过left、right、top、bottom属性肯定元素在正常文档流中的偏移位置。相对定位完成的过程是首先按static(float)方式生成一个元素(而且元素像层同样浮动了起来),而后相对于之前的位置移动,移动的方向和幅度由left、right、top、bottom属性肯定,偏移前的位置保留不动。
相对定位(fixed):表示固定定位,与absolute定位类型相似,但它的相对移动的坐标是视图(屏幕内的网页窗口)自己。因为视图自己是固定的,它不会随浏览器窗口的滚动条滚动而变化,除非你在屏幕中移动浏览器窗口的屏幕位置,或改变浏览器窗口的显示大小,所以固定定位的元素会始终位于浏览器窗口内视图的某个位置,不会受文档流动影响,这与background-attachment:fixed;属性功能相同。如下代码能够实现相对于浏览器视图向右移动100px,向下移动50px。而且拖动滚动条时位置固定不变。
水平居中设置-行内元素
若是被设置元素为文本、图片等行内元素时,水平居中是经过给父元素设置 text-align:center 来实现的。
水平居中设置-定宽块状元素(定宽块状元素:块状元素的宽度width为固定值。)
知足定宽和块状两个条件的元素是能够经过设置“左右margin”值为“auto”来实现居中的。