CSS布局——display,position,float属性
页面布局,或者是在页面上做些小效果的时候经常会用到 display,position和float 属性,如果对它们不是很了解的话,很容易出现一些莫名其妙的效果,痛定思痛读了《CSS Mastery》后总结一下。
让我们从基础的CSS知识谈起,相信很多初学者和小弟一样不明白CSS原理,一味追求效果,结果页面漏洞百出,错误匪夷所思,关于盒模型我就不多说了,网上很多,注意一下IE和其他浏览器(W3C规范)的区别就好了。
块级元素与行内元素
首先谈谈人们经常提及的块级元素和行内(内联)元素
p, ul, form, div等元素被称为块级元素,这些元素显示为一块儿内容(会自动换行),span, input 等元素称为行内元素,这两者主要区别就是块级元素会从上到下一个个垂直排列,每个自占一行,如下即使两个div之间没任何元素,绿色的div仍然会显示在hongsediv下方,而不是右方
<div style="height: 100px; width: 100px; background-color: Red;"></div><div style="height: 100px; width: 100px; background-color: Green;"></div>
而行内元素在一行中水平排列,行内元素的高度由其内容撑开,不可显示的设置其高度,这就是为什么我们一次次的在span上设置height属性不好使的原因。
简单了解了这些知识,让我们看看display常用的几个属性,一些不太常用的我也不明白,就不说了
值 | 描述 |
none |
此元素不会被显示。 |
block |
此元素将显示为块级元素,此元素前后会带有换行符。 |
inline |
此元素会被显示为内联元素,元素前后没有换行符。 |
inline-block |
行内块元素。(CSS2.1 新增的值) |
我们在显示隐藏元素的时候经常会用到把display设为none或者’’,设为none效果很明显,就是让元素脱离文档流,不显示,不占文档空间,而设为’’其实就是设置为元素默认属性block或inline,inline-block属性是CSS2.1新加值,IE8以上及其他主流浏览器都已经支持,它可以使元素像行内元素那样水平一次排列,但是框的内容符合块级元素行为,能够显示设置宽,高,内外边距。很有意思。
还有一点儿很有意思,可以通过不同的赋值改变元素生成框的类型,也就是说,通过将display属性设置为block,可以使行内元素表现的想块级元素一样,反之亦然。
定位
要想了解CSS元素定位就需要了解position属性了,position属性有几个常用值如下
值 | 属性 |
inhert |
规定应该从父元素继承 position 属性的值。 |
static |
默认值。没有定位,元素出现在正常的流中(忽略 top, bottom, left, right 或者 z-index 声明)。 |
relative |
生成相对定位的元素,相对于元素本身正常位置进行定位。因此,"left:20" 会向元素的 LEFT 位置添加 20 像素。 |
absolute |
生成绝对定位的元素,相对于 static 定位以外的第一个祖先元素进行定位。元素的位置通过 "left", "top", "right" 以及 "bottom" 属性进行规定。 |
fixed |
生成绝对定位的元素,相对于浏览器窗口进行定位。元素的位置通过 "left", "top", "right" 以及 "bottom" 属性进行规定。 |
CSS有三种基本的定位机制:普通流,浮动和绝对定位
普通流是默认定位方式,在普通流中元素框的位置由元素在html中的位置决定,元素position属性为static或继承来的static时就会按照普通流定位,这也是我们最常见的方式。
相对定位比较简单,对应position属性的relative值,如果对一个元素进行相对定位,它将出现在他所在的位置上,然后可以通过设置垂直或水平位置,让这个元素相对于它自己移动,在使用相对定位时,无论元素是否移动,元素在文档流中占据原来空间,只是表现会改变。
普通流:
<div style="border: solid 1px #0e0; width:200px;"><div style="height: 100px; width: 100px; background-color: Red;"></div><div style="height: 100px; width: 100px; background-color: Green;"></div><div style="height: 100px; width: 100px; background-color: Red;"></div></div>
相对定位:
<div style="border: solid 1px #0e0; width:200px;"><div style="height: 100px; width: 100px; background-color: Red;"></div><div style="height: 100px; width: 100px; background-color: Green; position:relative; top:20px; left:20px;"></div><div style="height: 100px; width: 100px; background-color: Red;"></div></div>
上面例子可以看出,对绿色div进行相对定位,分别右移,下移20px后第二个红色div位置并没有相应变化,而是在原位置,绿色div遮挡住了部分红色div。
相对定位可以看作特殊的普通流定位,元素位置是相对于他在普通流中位置发生变化,而绝对定位使元素的位置与文档流无关,也不占据文档流空间,普通流中的元素布局就像绝对定位元素不存在一样。
绝对定位的元素的位置是相对于距离他最近的非static祖先元素位置决定的。如果元素没有已定位的祖先元素,那么他的位置就相对于初始包含块儿(body或html神马的)元素。
因为绝对定位与文档流无关,所以绝对定位的元素可以覆盖页面上的其他元素,可以通过z-index属性控制叠放顺序,z-index越高,元素位置越靠上。
还是刚才的例子,稍微改动一下,让绿色div绝对定位,为了清晰显示,第二个红色div改为黄色。
<div style="border: solid 1px #0e0; width:200px; position:relative;"><div style="height: 100px; width: 100px; background-color: Red;"></div><div style="height: 100px; width: 100px; background-color: Green; position:absolute; top:20px; left:20px;"></div><div style="height: 100px; width: 100px; background-color: Yellow;"></div></div>
这时可以看出,绿色div是相对于父元素,也就是绿框div进行的移位,而红色和黄色div进行布局时就像绿色div不存在一样。
最后要说的就是fixed属性了,应用fixed也叫固定定位,固定定位是绝对定位的中,固定定位的元素也不包含在普通文档流中,差异是苦丁元素的包含块儿是视口(viewport),经常见一些页面的如人人网看在线好友那个模块总在窗口右下角,估计用的是类似技术
固定定位:
<div style="border: solid 1px #0e0; width:200px;"><div style="height: 100px; width: 100px; background-color: Red;"></div><div style="height: 100px; width: 100px; background-color: Green; position:fixed; bottom:20px; left:20px;"></div><div style="height: 100px; width: 100px; background-color: Yellow;"></div></div>
可见hongse和黄色div布局没有受到绿色div影响,而无论是页面纵向滚动条在页面顶端还是底端,绿色div总是在视口左下角
不浮动 <div style="border: solid 5px #0e0; width:300px;"><div style="height: 100px; width: 100px; background-color: Red;"></div><div style="height: 100px; width: 100px; background-color: Green; "></div><div style="height: 100px; width: 100px; background-color: Yellow;"></div></div>
//红向右浮动 <div style="border: solid 5px #0e0; width:300px;"><div style="height: 100px; width: 100px; background-color: Red; float:right;"></div><div style="height: 100px; width: 100px; background-color: Green; "></div><div style="height: 100px; width: 100px; background-color: Yellow;"></div></div>
//红框左移,覆盖绿框 <div style="border: solid 5px #0e0; width:300px;"><div style="height: 100px; width: 100px; background-color: Red; float:left;"></div><div style="height: 100px; width: 100px; background-color: Green;"></div><div style="height: 100px; width: 100px; background-color: Yellow;"></div></div>
//都向左浮动,父元素宽度为0<div style="border: solid 5px #0e0; width:300px;"><div style="height: 100px; width: 100px; background-color: Red; float:left;"></div><div style="height: 100px; width: 100px; background-color: Green; float:left;"></div><div style="height: 100px; width: 100px; background-color: Yellow; float:left;"></div></div>
如果包含块儿太窄无法容纳水平排列的三个浮动元素,那么其它浮动块儿向下移动,,直到有足够的扣减,如果浮动元素的高度不同,那么下下移动的时候可能被卡住
没有足够水平空间 <div style="border: solid 5px #0e0; width:250px;"><div style="height: 100px; width: 100px; background-color: Red; float:left;"></div><div style="height: 100px; width: 100px; background-color: Green; float:left;"></div><div style="height: 100px; width: 100px; background-color: Yellow; float:left;"></div></div>
卡住了 <div style="border: solid 5px #0e0; width:250px;"><div style="height: 120px; width: 100px; background-color: Red; float:left;"></div><div style="height: 100px; width: 100px; background-color: Green; float:left;"></div><div style="height: 100px; width: 100px; background-color: Yellow; float:left;"></div></div>
行框和清理
前面指出浮动会让元素脱离文档流,不影响不浮动元素.实际上并不完全如此,如果浮动的元素后面有一个文档流中元素,那么这个元素的框会表现的像浮动元素不存在,但是框的文本内容会受到浮动元素的影响,会移动以留出空间.用术语说就是浮动元素旁边的行框被缩短,从而给浮动元素流出空间,因而行框围绕浮动框。
不浮动 <div style="border: solid 5px #0e0; width: 250px;"><div style="height: 50px; width: 50px; background-color: Red;"></div><div style="height: 100px; width: 100px; background-color: Green;">1111111111111111111111</div></div>
浮动<div style="border: solid 5px #0e0; width: 250px;"><div style="height: 50px; width: 50px; background-color: Red; float:left;"></div><div style="height: 100px; width: 100px; background-color: Green;">1111111111111111111111</div></div>
可以看出浮动后虽然绿色div布局不受浮动影响,正常布局,但是文字部分却被挤到了红色浮动div下边。要想阻止行框围绕在浮动元素外边,可以使用clear属性,属性的left,right,both,none表示框的哪些边不挨着浮动框。
<div style="border: solid 5px #0e0; width: 250px;"><div style="height: 50px; width: 50px; background-color: Red; float:left;"></div><div style="height: 100px; width: 100px; background-color: Green; clear:both;">1111111111111111111111</div></div>
对元素清理实际上为前面的浮动元素留出了垂直空间,这样可以解决我们之前的一个问题,看前面的图片的时候我们发现div内的所有元素浮动的话就会不占据文档空间,这样父元素,高度为0,可能很多效果也不见了
//都向左浮动,父元素宽度为0<div style="border: solid 5px #0e0; width:300px;"><div style="height: 100px; width: 100px; background-color: Red; float:left;"></div><div style="height: 100px; width: 100px; background-color: Green; float:left;"></div><div style="height: 100px; width: 100px; background-color: Yellow; float:left;"></div></div>
如果我们想让父元素在视觉上包围浮动元素可以向下面这样处理
在最后添加一个空div,对它清理
<div style="border: solid 5px #0e0; width:300px;"><div style="height: 100px; width: 100px; background-color: Red; float:left;"></div><div style="height: 100px; width: 100px; background-color: Green; float:left;"></div><div style="height: 100px; width: 100px; background-color: Yellow; float:left;"></div><div style="clear:both;"></div></div>
当然这样做有很多缺点,有些javascript也可以做出类似效果,这里不细说,值得注意的是应用值为hidden或auto的overflow属性会有一个副作用:自动清理包含的任何浮动元素,所以说当页面出现相关问题时,可以看看是不是这个属性搞的鬼。
这样,有了这些基本知识后,我们应用CSS的时候就可以解决很多以前很百思不得其解的问题了。
转载于:https://www.cnblogs.com/onlywujun/archive/2013/05/23/3094343.html
CSS布局——display,position,float属性相关推荐
- CSS 布局 - display 属性
CSS 布局 - display 属性
- float属性html,详解CSS样式中的float属性
详解CSS样式中的float属性.float是 css 样式的定位属性.我们在印刷排版中,文本可以按照需要围绕图片.一般把这种方式称为"文本环绕".在网页设计中,应用了CSS的fl ...
- 转发- css(display,float,position)
此文章仅为转发,非原创,原文http://www.cnblogs.com/zhuanggege/p/5778309.html 请支持原创 display 用来设置元素的显示方式 display : b ...
- CSS中的position定位属性
一.文档流 在分析position定位之前可以先简单了解下CSS中的脱离文档流是什么意思. 文档流:可以理解为元素的一种状态,处于这种状态下的元素具有一些特性. (更加详细的文档流讲解可到<关于 ...
- CSS布局(二) 盒子模型属性
盒子模型的属性 宽高width/height 在CSS中,可以对任何块级元素设置显式高度. 如果指定高度大于显示内容所需高度,多余的高度会产生一个视觉效果,就好像有额外的内边距一样: 如果指定高度小于 ...
- css 效果-uni-app 使用 float 属性实现环绕之后文字最多显示两行
效果 思路 这个效果是文本环绕标签组件最多显示两行,京东app也有这个效果 环绕效果我们使用float:left实现环绕,文字最多显示两行,我一开始想到的是用下面的代码实现: display: -we ...
- html相对位置置顶,css定位(position)属性怎么用?
在CSS中,定位(position)属性用于规定元素的定位类型,定义建立元素布局所用的定位机制.下面给大家介绍一下position属性,有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助. ...
- 微信小程序CSS布局—display:flex
display:flex 是一种布局方式.它即可以应用于容器中,也可以应用于行内元素. 设为Flex布局以后,子元素的float.clear和vertical-align属性将失效. flex的六种属 ...
- div+css中设置了float属性后如何让外层的高度随着内层的高度大小自动调整
overflow:hidden这个CSS样式是大家常用到的CSS样式,但是大多数人对这个样式的理解仅仅局限于隐藏溢出,而对于清除浮动这个含义不是很了解. 一提到清除浮动,我们就会想到另外一个CSS样式 ...
最新文章
- android 重绘如何能不闪一下屏幕_浏览器渲染机制——重绘重排
- unable to access ‘https://gitee...‘: Failed to connect to 127.0.0.1 port 31181 after 2029 ms: Connec
- 数论初步——同余与模算术
- JavaFX技巧1:可调整大小的Canvas
- linux环境下安装多个任意版本的python环境
- 详解:设计模式之-适配器模式
- linux环境变量介绍
- 深入讲解防火墙的概念原理与实现
- 服务器的配置文档在哪里找,服务器端的数据库配置怎么找
- 2016年第四季度思科称霸印度网络市场
- python做图书馆管理系统-为什么我学了一个月python基础了,还写不出简单图书馆系统?...
- 单片机课设中期报告_毕业论文--中期检查情况报告(40页)详解.doc
- (判断题)两台路由器之间转发的数据包一定不携带VLAN TAG?
- 搜狐Q3由盈转亏:预计全年收入下滑12%,张朝阳归因于不确定性
- 【Tool】常用 GIT 命令参阅
- 沟通的艺术(笔记)——前言
- 强网杯2018 - nextrsa - Writeup
- mac关闭VPN之后,浏览器就不能够正常上网了(图解)
- (一)R语言入门指南——数据分析的第一步
- Photoshop切片工具的使用
热门文章
- 学习C++ - 类(Classes)的定义与实现
- python一球从100米高度自由落下,一球从100米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在 第10次落地时,......
- 收费标准_互联网推广收费标准
- leetcode 62 不同路径
- python怎么定义文档的行数_python删除文本中行数标签的方法
- 交叉驰豫的影响因素_交叉滚子轴承系列吉林薄壁交叉滚子轴承用途博盈
- JVM 调优参数详解
- LeetCode 215 Kth Largest Element in an Array
- 二.Sql语言的分类及运算符
- Web公路,新手上路!NO.2 [ 基础标签(一)]