登录  /  注册
CSS相对定位、绝对定位_html/css_WEB-ITnose
php中文网
发布: 2016-06-24 11:38:01
原创
856人浏览过

  CSS定位属性:position。

  定位的基本思想:定义元素框相对于其正常位置应该出现的位置,或者相对于父元素、另一个元素或浏览器窗口本身的位置。

  position属性值:static、relative、absolute、fixed。

  以下所有测试在Firefox40.0下进行。

  所用到基本代码:

  

 1 
登录后复制

  

1 2     
div2
div1
3
div3
4
div4
5
登录后复制

  

  普通定位:static,默认情况。不设置position属性时,会按照正常的文档流进行排列。

  固定定位:fixed,绝对定位的第二种情况(见下文)。

  相对定位:relative,元素框偏移某个距离(相对于它原来的位置),它原本的位置空间仍然保留。

1 .div3{2     background-color: pink;3     width: 80px;4     height: 50px;5     position: relative;6     left: 300px;7 }
登录后复制

  

  DIV3向左偏移了300px,原来的位置还在(DIV4并没有贴上去)。

  在元素有父元素的情况下,也是一样的。

  

1 .div2{2     width: 50px;3     height: 50px;4     background-color: blue;5     position: relative;6     left: 250px;7 }
登录后复制

  绝对定位:元素框在正常文档流中所占据空间关闭,并相对于其包含框定位。包含框可能是文档中的另一个元素框或者是窗口本身。元素定位后生成一个块级框,而不论原来它在正常流中生成何种类型的框。

  分两中情况:

  1. 父元素/祖先元素定位方式为relative或absolute,则相对于此父元素/祖先元素定位,定位起点为父元素/祖先元素的左上角。请注意:如果父元素/祖先元素设置了padding,则从内边距左上角开始定位。
  2. 父元素/祖先元素都没有相对或绝对定位,则相对于浏览器窗口定位(相对于窗口的左上角,不考虑body的内外边距)。

  第一种情况:

  

.div1{    position: relative;    width: 200px;    height: 200px;        padding: 50px;    background: red;}.div2{    position: absolute;    left: 300px;    top: 0;    width: 50px;    height: 50px;        background-color: blue;}        
登录后复制

  

  从上图明显看到,DIV2向左偏移300px,是从内边距左上角开始的,而不是DIV2原始的位置(如果padding为0,则是从原始的位置)。

  设置DIV1的外边距为30px,DIV2偏移left、top都为0。

 1 .div1{ 2     position: relative; 3     margin: 30px; 4     width: 200px; 5     height: 200px; 6     padding: 50px; 7     background: red; 8 } 9 .div2{10     position: absolute;11     left: 0;12     top: 0;13     width: 50px;14     height: 50px;15     background-color: blue;16 }
登录后复制

  

  可见,在父元素框有外边距的情况下,偏移也是从内边距开始的。

  第二种情况:

  body内边距增加30px,DIV2向右偏移360px。

body{    margin: 30px 0 0 30px;    padding: 30px;}.div1{        width: 200px;    height: 200px;    padding: 50px;    background: red;}.div2{    position: absolute;    left: 360px;    top: 60px;    width: 50px;    height: 50px;    background-color: blue;}    
登录后复制

  

  左边body空白处有外边距、内边距各30px,DIV2偏移30px+30px+300px=360px,刚好与DIV1对齐。证明偏移是从窗口的左上角,而不用管内外边距!

来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 技术文章
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2023 //m.sbmmt.com/ All Rights Reserved | 苏州跃动光标网络科技有限公司 | 苏ICP备2020058653号-1

 | 本站CDN由 数掘科技 提供

登录PHP中文网,和优秀的人一起学习!
全站2000+教程免费学