夜鹰教程网-程序员的加油站
 当前位置:文章中心 >> Css3.0_css2.0_html5
彻底搞清楚position
夜鹰教程网 来源:www.yyjcw.com 日期:2017-11-4 23:51:40
彻底搞清楚position

position俗称定位,主要取值及作用如下:


static


默认值。没有定位,出现在正常文档流中


absolute


绝对定位,相对于position为absolute、relative、fixed的第一个父元素进行定位


relative


相对定位,相对于其正常位置进行定位


fixed


绝对定位,相对于浏览器窗口进行定位


Position本不复杂,混淆应用比较难理解,主要规则如下:


脱离文档流

除 static属性值之外,其他值都会使元素脱离文档流(float也会导致元素脱离文档流)。


对 Width、height的影响

1) Absolute的参考点为最近可作为参考点的父元素(position为absolute、relative、fixed的元素)、fixed的参考点浏览器窗口、relative的参考点为元素正常位置。


2) 元素本身值为inherit时


a) 当父级元素的Width和height值为数值时,元素继承父级元素的完整高度,并以最近参考点作为参考。



.wrap{

            position: relative;

            width: 500px;

            height: 300px;

            border: 1px solid red;

        }

        .cont{

            background: gray;

            width: 150px;

            overflow: hidden;

        }

        .txt{

            background: yellow;

            width: 230px;

            height: inherit;

        }

        .banner{

            background: pink;

            width: 50%;

            height: inherit;

        }

        .txt-cont{

            position: absolute;

            background: darkblue;

            width: inherit;

            color: white;

        }



<div class="wrap">

        <div class="cont">

            cont            <div class="txt">

                txtxtxt                <div class="txt-cont">

                    txt-cont                </div>

            </div>

            <div class="banner">

                banner            </div>

        </div></div>




b) 当父级元素的Width和height值为百分比时,以参考点元素的宽、高* 百分比来计算。



.wrap{

            position: relative;

            width: 500px;

            height: 300px;

            border: 1px solid red;

        }

        .cont{

            background: gray;

            width: 150px;

            overflow: hidden;

        }

        .txt{

            background: yellow;

            width: 50%;

            height: inherit;

        }

        .banner{

            background: pink;

            width: 50%;

            height: inherit;

        }

        .txt-cont{

            position: absolute;

            background: darkblue;

            width: inherit;

            color: white;

        }



<div class="wrap">

        <div class="cont">

            cont            <div class="txt">

                txt                <div class="txt-cont">

                    txt-cont                </div>

            </div>

            <div class="banner">

                banner            </div>

        </div></div>




 


3) 元素本身为百分比时(50%)


此种情况下,无论父级元素的width和height是数值,还是百分比都不会造成对元素自身的影响,元素自身还是会以参考进行相应的计算。



.wrap{

            position: relative;

            width: 500px;

            height: 300px;

            border: 1px solid red;

        }

        .cont{

            background: gray;

            width: 150px;

            overflow: hidden;

        }

        .txt{

            background: yellow;

            width: 50%;

            height: inherit;

        }

        .banner{

            background: pink;

            width: 50%;

            height: inherit;

        }

        .txt-cont{

            position: absolute;

            background: darkblue;

            width: 100%;

            color: white;

        }


<div class="wrap">

        <div class="cont">

            cont            <div class="txt">

                txt                <div class="txt-cont">

                    txt-cont                </div>

            </div>

            <div class="banner">

                banner            </div>

        </div></div>




定位后的默认位置

Fixed和absolute属性后的默认位置都是在原地,只是紧跟后面折正常文档流元素会顶上来,被定位元素盖住。


他与z-index无解的关系

z-index的详细介绍见后面章节,此处只指出position除static值外都会创建层叠上下文(z-index不为auto的时候)。


1) z-index为数值时,会创建层叠上下文,子元素层叠顺序以此做为参考。


2) z-index为auto时,不会创建层叠上下文,层叠顺序与z-index:0一致。


复制链接 网友评论 收藏本文 关闭此页
上一条: 四种扩展名 .html 、.htm 、 .sht…  下一条: Html5和css3制作动画学习笔记
夜鹰教程网成立于2008年,目前已经运营了将近 13 年,发布了大量关于 html5/css3/C#/asp.net/java/python/nodejs/mongodb/sql server/android/javascript/mysql/mvc/easyui/vue/echarts原创教程。 我们一直都在坚持的是:认证负责、一丝不苟、以工匠的精神来打磨每一套教程,让读者感受到作者的用心。我们默默投入的时间,确保每一套教程都是一件作品,而不是呆板的文字和视频! 目前我们推出在线辅导班试运营,模式为一对一辅导,教学工具为QQ。我们的辅导学科包括 java 、android原生开发、webapp开发、商城开发、C#和asp.net开发,winform和物联网开发、web前端开发,但不仅限于此。 普通班针对的是国内学员,例如想打好基础的大学生、想转行的有志青年、想深入学习的程序员、想开发软件的初学者或者业余爱好者等。 就业办针对即将毕业上岗的大四学生,或者打算转行的初级开发工程师。 留学生班针对的是在欧美、加拿大、澳洲、日本、韩国、新加坡等地留学的中国学子,目的是让大家熟练地掌握编程技能,按时完成老师布置的作业,并能顺利地通过考试。 详细咨询QQ:1416759661   夜鹰教程网  基于角色的权限管理系统(c-s/b-s)。
  夜鹰教程网  基于nodejs的聊天室开发视频教程
  夜鹰教程网  Git分布式版本管理视频教程
  夜鹰教程网  MVC+EasyUI视频教程
  夜鹰教程网  在线考试系统视频教程
  夜鹰教程网  MongoDB视频教程。
  夜鹰教程网 Canvas视频教程
  夜鹰教程网 报表开发视频教程
  热点推荐
什么是css框架
meta标签实现页面的动感效果
CSS半透明滤镜在FIREFOX和IE下面的…
div+css鼠标悬停在div上,div背景色…
纯css下拉菜单特效
div+css的浏览器兼容问题
CSS定义表格线为单一线
CSS滤镜效果收集(全)
列表显示文字和图片垂直居中对齐
在固定位置显示背景图片
网站变换图片的显示方法
在select外面套一个div或span, se…
常用的CSS命名规则
闪字闪字闪字闪字闪字闪字闪字闪字…
css让图片自动适应表格大小
  最近更新
HTTP协议实现文件断点续传
H5实现断点上传
行内元素和块级元素汇总
H5视频直播技术介绍
border-image详解
你必须知道的HTML5的新特性
html5 js控制音乐播放
HTML+CSS代码规范
css3学习笔记 transition与animat…
css3学习笔记Transform
css3学习笔记2D或3D转换
css3学习笔记文本特效
css3学习笔记颜色和透明度
css3学习笔记二
css3学习笔记一

关于我们 | 网站建设 | 技术辅导 | 常见问题 | 联系我们 | 友情链接

夜鹰教程网 版权所有 www.yyjcw.com All rights reserved 备案号:蜀ICP备08011740号3