码迷,mamicode.com
首页 > Web开发 > 详细

css定位机制

时间:2018-08-23 10:47:00      阅读:162      评论:0      收藏:0      [点我收藏+]

标签:输出   文档   pos   实现   tom   定位   相同   分享图片   综合   

  • time: 2016-02-19 14:00

每次用div+css布局的时候都混乱的不行,所以决定仔细梳理一遍,加强理解和记忆^^。

一.文档流是什么?

    CSS 有三种基本的定位机制:普通流、浮动和绝对定位。除非专门指定,否则所有框都在普通流中定位。块级框从上到下一个接一个地排列,框之间的垂直距离是由框的垂直外边距计算出来。行内框在一行中水平布置。可以使用水平内边距、边框和外边距调整它们的间距。但是,垂直内边距、边框和外边距不影响行内框的高度。

    “文档“”就是网页的页面,doctype;“流”就是指页面上的元素输入输出的形式和顺序,其中“输入”是布局,输出是“显示”;综合起来就是:页面布局+显示的形式。

二.position详解

在css中,通过position属性,配合top,right,left,buttom对元素进行定位。

position属性有:static,relative,absolute,fixed,下面来详细分析:

1.默认定位:static

块元素相对于浏览器布局,一行一个,自动换行。

技术分享图片

显示结果:

技术分享图片

2.相对定位:relative

相对定位就应该是相对于一个东西来定位,而这个东西就是元素自己本身,用left right top b0ttom进行定位后,元素会根据原来的位置进行移动,但由于position:relative这个属性并没有脱离文档流的,所以元素本身所占的位置会保留。

  • 现在我给第二个块加上一个样式:

技术分享图片

显示结果:
块二通过position:relative相对于原来的位置左移50px; 上移20px得到的,而且块三并没有因为块二的上移而上移,原因就是position:relative这个属性是没有脱离文档流的,所以元素本身所占的位置会保留。

技术分享图片

3.绝对定位:absolute

所谓绝对定位,其实也是相对于某个东西来绝对定位,而这个东西就是靠元素的最近的一个有position,且positon不能为static的祖先元素,一般来说是position为relative的父级元素,如果没有,则相对于body定位;值得注意的是position:absolute这个属性是脱离文档流的,所以重新定位后元素是不会占着原来的位置的,从原来的文档中分离被孤立了出来。

  • 现在我再修改一下代码,将dad父元素的position设置为relative,块二的position设置为absolute:

技术分享图片

显示结果:块二相对于dad块下边界20px,相对于dad块左边界50px;而块三向上移动占据了本来属于块二的位置,原因在于position:absolute这个属性是脱离文档流的,所以重新定位后元素是不会占着原来的位置的,从原来的文档中分离被孤立了出来。

技术分享图片

4.固定定位:fixed

元素框的表现类似于将 position 设置为 absolute,不过其包含块是视窗本身,它的位置始终相对于窗口,可以实现固定导航栏的效果,也这意味着即便页面滚动,它还是会停留在相同的位置, top 、 right 、 bottom 和 left 属性都可用。

css定位机制

标签:输出   文档   pos   实现   tom   定位   相同   分享图片   综合   

原文地址:https://www.cnblogs.com/evaxtt/p/9522179.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!