html+css布局整理笔记

基本概念


### 布局模型 1. 流动模型(Flow) 2. 浮动模型(Float) 3. 层模型(Layer)
### 流动模型 默认的网页布局模式,流动布局模型有两个比较典型的特征: 第一,块级元素都会在所处的包含元素内自上而下按顺序垂直延伸分布,且默认状态下,会计元素的宽度都为包含元素宽度的**100%**,即块级元素都会以**行的形式占据位置**。 第二,内联元素都会在所处的包含元素内**从左到右水平分布**,自然宽度取决于内容宽度(不考虑换行的情况下)。
### 浮动模型 任何元素在默认状态下都是不能浮动的,可以通过css定义其float属性让元素浮动。
css:
div{
    width:200px;
    height:200px;
    border:2px red solid;
    float:left;(左对齐,相对的也有右对齐[right]
}
html:
<div id="div1"></div>
<div id="div2"></div>

浏览器效果:


### 层模型 层布局模型就像是图像软件PhotoShop中非常流行的图层编辑功能一样,让每个图层能够精确定位操作。 层模型有三种主要形式: 1. 绝对定位(position:absolute) 2. 相对定位(position:relative) 3. 固定定位(position:fixed)

4. 默认定位(position:static)

绝对定位
如果想为元素设置层模型中的绝对定位,需要设置position:absolute(表示绝对定位),这条语句的作用将元素从文档流中拖出来,然后使用left、right、top、bottom属性相对于其最接近的一个具有定位属性的父包含块进行绝对定位。如果不存在这样的包含块,则相对于body元素,即相对于浏览器窗口
如下面代码可以实现div元素相对于浏览器窗口向右移动100px,向下移动50px。

css:
div{
    width:200px;
    height:200px;
    border:2px red solid;
    position:absolute;
    left:100px;
    top:50px;
}
html:
<div id="div1"></div>

效果图:

相对定位
相对定位完成的过程是首先按static(float)方式生成一个元素(并且元素像层一样浮动了起来),然后相对于以前的位置移动,移动的方向和幅度由left、right、top、bottom属性确定,偏移前的位置保留不动。值得一提的是:实际上,元素还是占着原本的位置,只是看起来发生了偏移。例如下面的例子:

css:
#div1{
    width:200px;
    height:200px;
    border:2px red solid;
    position:relative;
    left:100px;
    top:50px;
}
html:
    <div id="div1"></div>
    <div id="div1"></div><span>偏移前的位置还保留不动,覆盖不了前面的div没有偏移前的位置</span>

从效果图中可以明显的看出,虽然div元素相对于以前的位置产生了偏移,但是div元素以前的位置还是保留着,所以后面的span元素是显示在了div元素以前位置的后面。

固定定位
fixed:表示固定定位,与absolute定位类型类似,但它的相对移动的坐标是视图(屏幕内的网页窗口)本身。由于视图本身是固定的,它不会随浏览器窗口的滚动条滚动而变化,除非你在屏幕中移动浏览器窗口的屏幕位置,或改变浏览器窗口的显示大小,因此固定定位的元素会始终位于浏览器窗口内视图的某个位置,不会受文档流动影响。最常见的就是网页中的那些广告。

Relative和Absolute的组合使用
由于绝对定位可以相对于已经定位了的父辈元素进行定位,所以就让块中的块居中或者任意定位成为可能:

css:
.superBox{
	width:200px;
	height:200px;
	position:relative;
	border:1px solid red;
}
.box{
	width:100px;
	height:100px;
	position:absolute;
	border:1px solid green;
	bottom:100px;
	right:100px;
}
html:
<div class="superBox">
    <div class="box"></div>
</div>

效果:


### 流的概念 流是页面的默认布局模式,可以把页面中所有的元素想象成水流,浏览器为一个容器(有时候也不一定是body),块元素独立成行,从上而下的流动,而内联元素则在块状元素中从左到右,自上而下的流动。 而浮动呢,就像是水流中的石头,如果在一个页面中设置了某个元素为浮动,那么他就相当于在水流中突出了一块石头 ,这块石头是不会随着水流流动,相反的,水流(流动元素)会尽量地绕开他流动,块状元素中的内联元素(包括文本)会绕过浮动元素进行排版,值得一提的是,浮动元素只能左右对齐,因为浏览器无法处理放置在中间的石头的水流走向。可以设置流动元素的clear值(也是只有左和右)来阻止流动元素绕过浮动元素,常见应用于页脚,以确保页脚能始终“高冷”地在页面的最下面。 而层呢,他更像是一个悬浮在水面上的叶子,水流在他底下无所顾忌的遵从流动法则流动,也可以有其他的树叶叠在他上面,对了,可以通过设置z-index大小来决定那些层在上面,z-index就像是一个Z轴,垂直于你的显示器屏幕,越大就说明离你越近。与浮动不同的是,层模型可以随意在页面的任何位置,通过设置其top、bottom、left、right值,使他能始终在浏览器窗口的相对位置。因为层元素遗立在页面之上,所以这时候clear值就没有用了,忘了你高冷的页脚吧,试试使她拥有跟主内容相同的背景色?

## html+div+css的布局模式
### 利用浮动构建两栏分布页面 首先用两个div构建逻辑分区,一个作为主内容区,一个作为边栏。一般来说,内容区在左,分栏在右。(博客园的是三栏,左右功能分栏,中间是主内容) 两栏分布实现的原理: 第一种选择,浮动边栏 先将边栏定义宽度,再将边栏div放置在内容区盒子前面,利用float,将边栏设置右浮动,这样内容区的内容就会在边栏周围流动,然后通过给内容区设置一定的右外边距,视情况给页尾设置clear值就大功告成了 如下栗子: ```html css: #dev{ width:360px; height:auto; border:1px solid red; background-color:green; float:right; } #main{ width:auto; /*宽度可以随着浏览器宽度改变*/ height:auto; border:1px solid blue; margin-right:202px; } html:
我是主内容
``` 效果: ![](https://images2018.cnblogs.com/blog/1322238/201803/1322238-20180327202052864-530696789.png)

主内容的宽度可以随着浏览器大小进行调整,本来做了gif动图看着很直观的,不过博客园的文章里好像显示不了动图……
这种布局由于边栏先于内容区,所以有些浏览器(特别是屏幕阅读器,手机浏览器)会先显示出边栏的内容,也就是说,你要活生生地等着屏幕阅读器将边栏内容念完你才能进入主内容……
知道了上面的两栏分布页面的布局原理后,你肯定能猜出三栏是怎么弄的,没错,三栏其实就是将左右边栏各自浮动,然后主内容设置恰当的左右margin就行了。

第二种,浮动内容区
这种跟上面浮动边栏类似,不同的是,将内容区的div放置在边栏前面,设置左浮动并定宽,然后给边栏一个恰当的左边距就ok了,这种布局虽然解决了主内容和边栏的先后问题,但是也衍生出了另一个小问题,就是当浏览器改变大小的时候,由于边栏没有定宽,你会看到一个超宽的边栏……

或许你会说,我把边栏设置一定的宽度不就可以了。没错,这的确可以防止超宽的边栏,但是这样就会让整个页面的右边留太多空白,还有可能导致页面只能蜷缩在超宽的显示器里的一角。
那么有没有一种可以在浏览器改变任意大小的时候,主内容和边栏比例不会变的奇怪,并且还能居中在页面的布局呢?


### 利用“凝胶”构建两栏页面(常见的果冻模型) 这个原理其实很简单,首先在最外部加一个div,定宽,这里就相当于把用户的浏览器视窗宽度固定死,然后左右margin设为自动,让这个div带着所有元素居中。将所有浮动的,流动的,都打包装进这个容器里面,凝固起来,这就是果冻这个称号的由来。 ![](https://images2018.cnblogs.com/blog/1322238/201803/1322238-20180327210015457-1936457283.png)
### 利用绝对定位构建两栏页面(实用) 这个办法其实是将边栏设定宽度之后,放置在页面的指定位置,然后主题内容设置一定的外边距,营造一种分栏的“假象”,博客园首页的三栏分布就是采用这种方式:将左右边栏绝对定位,然后主内容设置相应的左右边距。 ![](https://images2018.cnblogs.com/blog/1322238/201803/1322238-20180327211227758-2117159676.png)
### 利用css表格显示布局 这种方法就是专治各种不服的存在了,利用div中的display属性,构建css表格,可以实现各种多栏布局。 话不多说,利用这个方法,首先你要有一个大的div,用display设置为table,装载所有行div和单元格div,然后每一个行指定另一个div(table-row),有多少个列就有多少个元素(单元格table-cell)。比如下面这个css表格:
CSS:
	#table{
	display:table;			
	border-spacing:10px;      /*为表格中的单元格增加10像素的边框边距,值得注意的是,这里的10像素不会跟页面中上下的其他块元素叠加,也就是说,表格跟上下其他块元素的外边距不是取最大,而是两者相加(边框间距+其他块元素的相应外边距*/
}
	.table-row{
	display:table-row;
	margin:10px;			/*边框间距可以看成是常规元素的外边距,所以可以不再需要<div>上的外边距*/
}
	#A,#B{
	display:table-cell;
	vertical-align:top;		/*表格中的内容垂直上对齐*/
}
HTML:
<div id="table">
	<div class="table-row">
		<div id="A">…………</div>
		<div id="B">…………</div>
	</div>
</div>


利用这种布局方法可以很轻便地做出多行多列的布局,只要将相应的html结构添加进去就搞定了。

posted @ 2018-03-27 21:42  宋步廷  阅读(3507)  评论(0编辑  收藏  举报