html+css布局整理笔记
基本概念
布局模型
- 流动模型(Flow)
- 浮动模型(Float)
- 层模型(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中非常流行的图层编辑功能一样,让每个图层能够精确定位操作。
层模型有三种主要形式:
- 绝对定位(position:absolute)
- 相对定位(position:relative)
- 固定定位(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值就大功告成了
如下栗子:
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: <!-- lipsum()类是一个乱数假文的api --> <div id="dev" class="lipsum(50,10)"></div> <!--这里边栏是在内容区前面的--> <div id="main" class="lipsum(100,30)">我是主内容</div>
效果:
主内容的宽度可以随着浏览器大小进行调整,本来做了gif动图看着很直观的,不过博客园的文章里好像显示不了动图……
这种布局由于边栏先于内容区,所以有些浏览器(特别是屏幕阅读器,手机浏览器)会先显示出边栏的内容,也就是说,你要活生生地等着屏幕阅读器将边栏内容念完你才能进入主内容……
知道了上面的两栏分布页面的布局原理后,你肯定能猜出三栏是怎么弄的,没错,三栏其实就是将左右边栏各自浮动,然后主内容设置恰当的左右margin就行了。
第二种,浮动内容区
这种跟上面浮动边栏类似,不同的是,将内容区的div放置在边栏前面,设置左浮动并定宽,然后给边栏一个恰当的左边距就ok了,这种布局虽然解决了主内容和边栏的先后问题,但是也衍生出了另一个小问题,就是当浏览器改变大小的时候,由于边栏没有定宽,你会看到一个超宽的边栏……
或许你会说,我把边栏设置一定的宽度不就可以了。没错,这的确可以防止超宽的边栏,但是这样就会让整个页面的右边留太多空白,还有可能导致页面只能蜷缩在超宽的显示器里的一角。
那么有没有一种可以在浏览器改变任意大小的时候,主内容和边栏比例不会变的奇怪,并且还能居中在页面的布局呢?
利用“凝胶”构建两栏页面(常见的果冻模型)
这个原理其实很简单,首先在最外部加一个div,定宽,这里就相当于把用户的浏览器视窗宽度固定死,然后左右margin设为自动,让这个div带着所有元素居中。将所有浮动的,流动的,都打包装进这个容器里面,凝固起来,这就是果冻这个称号的由来。
利用绝对定位构建两栏页面(实用)
这个办法其实是将边栏设定宽度之后,放置在页面的指定位置,然后主题内容设置一定的外边距,营造一种分栏的“假象”,博客园首页的三栏分布就是采用这种方式:将左右边栏绝对定位,然后主内容设置相应的左右边距。
利用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结构添加进去就搞定了。
上一篇: storage事件 js页面间通信
下一篇: 正则表达式
推荐阅读
-
javascript笔记整理系列-函数
-
Flutter学习笔记(22)--单个子元素的布局Widget
-
JavaScript学习笔记整理_简单实现枚举类型,扑克牌应用
-
JavaScript学习笔记整理_关于表达式和语句
-
JavaScript学习笔记整理_setTimeout的应用
-
MySQL 笔记整理(19) --为什么我只查一行的语句,也执行这么慢?
-
IOS开发笔记整理49之详解定位CLLocation
-
PHP随手笔记整理之PHP脚本和JAVA连接mysql数据库
-
Python学习笔记整理3之输入输出、python eval函数
-
MySQL 笔记整理(16) --“order by”是怎么工作的?