2016.3.14CSS 定位第六天_html/css_WEB-ITnose

CSS定位 CSS 定位机制

css中一共有三种基本定位机制:普通流、浮动、绝对定位。
如果不进行专门指定,所有的标签都在普通流中定位。
块级元素从上到下一个接一个的排列,框之间的垂直距离是由框的垂直外边距计算出来。
行内框在一行中水平布置。可以使用水平内边距、边框和外边距来调整它们之间的间距。

position属性

通过position属性,我们可以选择4种不同类型的定位,这会影响元素框生成的方式。
包括4个属性值:static、relative、absolute、fixed

static : 元素框正常生成。块级元素生成一个矩形框,作为文档流的一部分;行内元素则会创建一个或多个行框,置于其父元素中。 relative : 元素框偏移某个距离。元素仍然保持其未定位前的形状,它原本所占的空间仍然保留。 absoulte : 元素框从文档流中完全删除,并相对于其包含块定位。元素原先在正常文档流中所占的空间会关闭,就好像元素不存在一样。元素定位后生成一个块元素,而不论原来它在正常文档流中生成何种类型的框。 fixed : 元素框的表现类似将position设置为absoulte,不过其包含块是浏览器窗口。

代码展示

position: static;

static是position属性的默认值,无特殊定位。均为正常定位。

立即学习“前端免费学习笔记(深入)”;

position: reletive;

HTML代码:

我是p1

我是p2

我是p3

登录后复制

CSS代码:

.p1 {    position: relative;    left: 30px;}.p2 {    position: relative;    right: 30px;}

登录后复制

效果图:

解释:

position: relative;参考的是自己原来得位置。 第一行文字设置postion为relative,这并不会造成什么反应,但是我们还给p1设置了left: 30px;,这就会使元素距离左侧产生30px的间距。 同样,第二行文字设置right: 30px,会使元素距离右侧30px的间距,就产生了跑到屏幕外面的情况 第三方没有做任何处理,正常显示 注意,一定要设置好position: relative;,否则top、right、bottom、left是不起作用的。

position: absoulte;

HTML代码:

啦啦啦啦啦

我是h1大标题

登录后复制

CSS代码:

.h1 {    position: absolute;    top: 100px;    left: 100px;}

登录后复制

没有设置CSS样式的样子:

设置了CSS样式后的样子:

解释:

postion: absolute;参考的是自身的包含块,也就是自己的父视图 当设置了position: absolute;属性之后,标签的位置就变得绝对了。这个时候我们设置top、right、bottom、left其中的任何一个属性,都可以设置标签的位置。 注意,一定要设置好position: absolute;,否则top、right、bottom、left是不起作用的。

position: fixed;

HTML代码:

我是p one

我是p two

登录后复制

CSS代码:

.one {    position: fixed;    top: 100px;    left: 30px;}.two {    position: fixed;    top: 50px;    right: 30px;}

登录后复制

效果展示:

解释:

position: fixed;参考系是浏览器的窗口 当给标签设置了position: fixed;属性之后,这些标签就只会相对于浏览器窗口进行位置的设定,忽略网页的滚动 同样,如果不设置postion: fixed;属性,而是直接设置top、right、bottom、left都不会起作用

参考文章:http://www.w3school.com.cn/css/css_positioning.asp

关于界面排布优先级的问题 z-index

    Document      div{      width: 100px;      font-size: 50px;      position: absolute;      height: 100px;    }    .a{      background-color: red;      left: 0;      top: 0;        /*设置优先级,数字越大,放置越靠前*/      z-index: 3;    }    .b{      background-color: blue;      left: 40px;      top: 40px;      z-index: 2;    }    .c{      background-color: green;      left: 80px;      top: 80px;      z-index: 100;    }  
1
2
3

登录后复制

关于界面元素框偏移
偏移前:

偏移后:

        Document        .wrap{        width: 300px;        height: 300px;        border: 1px solid red;        margin: 100px;        padding: 100px;        position: relative;        padding-left: 0;    }    .inner{        width: 200px;        height: 200px;        background-color: green;        padding: 50px;        position: relative;    }    .content{        width: 50px;        height: 50px;        background-color: red;        position: absolute;        left: 0;    }            

登录后复制

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/3112669.html

(0)
上一篇 2025年3月29日 11:41:36
下一篇 2025年3月29日 11:41:40

AD推荐 黄金广告位招租... 更多推荐

发表回复

登录后才能评论