CSS position 属性

实例

定位 h2 元素:

  1. h2
  2. {
  3. position:absolute;
  4. left:100px;
  5. top:150px;
  6. }

浏览器支持


IE Firefox Chrome Safari Opera
ie firefox chrome safari opera

所有主流浏览器都支持 position 属性。

注释:任何的版本的 Internet Explorer (包括 IE8)都不支持属性值 "inherit"。

定义和用法

position 属性规定元素的定位类型。

说明

这个属性定义建立元素布局所用的定位机制。任何元素都可以定位,不过绝对或固定元素会生成一个块级框,而不论该元素本身是什么类型。相对定位元素会相对于它在正常流中的默认位置偏移。

默认值: static
继承性: no
版本: CSS2
JavaScript 语法: object.style.position="absolute"

可能的值

描述
absolute 生成绝对定位的元素,相对于 static 定位以外的第一个父元素进行定位。 元素的位置通过 "left", "top", "right" 以及 "bottom" 属性进行规定。
fixed 生成绝对定位的元素,相对于浏览器窗口进行定位。 元素的位置通过 "left", "top", "right" 以及 "bottom" 属性进行规定。
relative 生成相对定位的元素,相对于其正常位置进行定位。 因此,"left:20" 会向元素的 LEFT 位置添加 20 像素。
static 默认值。没有定位,元素出现在正常的流中(忽略 top, bottom, left, right 或者 z-index 声明)。
inherit 规定应该从父元素继承 position 属性的值。

实例

定位:相对定位

本例演示如何相对于一个元素的正常位置来对其定位。

  1. <html>
  2. <head>
  3. <style type="text/css">
  4. h2.pos_left
  5. {
  6. position:relative;
  7. left:-20px
  8. }
  9. h2.pos_right
  10. {
  11. position:relative;
  12. left:20px
  13. }
  14. </style>
  15. </head>
  16. <body>
  17. <h2>这是位于正常位置的标题</h2>
  18. <h2 class="pos_left">这个标题相对于其正常位置向左移动</h2>
  19. <h2 class="pos_right">这个标题相对于其正常位置向右移动</h2>
  20. <p>相对定位会按照元素的原始位置对该元素进行移动。</p>
  21. <p>样式 "left:-20px" 从元素的原始左侧位置减去 20 像素。</p>
  22. <p>样式 "left:20px" 向元素的原始左侧位置增加 20 像素。</p>
  23. </body>
  24. </html>

定位:绝对定位

本例演示如何使用绝对值来对元素进行定位。

  1. <html>
  2. <head>
  3. <style type="text/css">
  4. h2.pos_abs
  5. {
  6. position:absolute;
  7. left:100px;
  8. top:150px
  9. }
  10. </style>
  11. </head>
  12. <body>
  13. <h2 class="pos_abs">这是带有绝对定位的标题</h2>
  14. <p>通过绝对定位,元素可以放置到页面上的任何位置。下面的标题距离页面左侧 100px,距离页面顶部 150px。</p>
  15. </body>
  16. </html>

定位:固定定位

本例演示如何相对于浏览器窗口来对元素进行定位。

  1. <html>
  2. <head>
  3. <style type="text/css">
  4. p.one
  5. {
  6. position:fixed;
  7. left:5px;
  8. top:5px;
  9. }
  10. p.two
  11. {
  12. position:fixed;
  13. top:30px;
  14. right:5px;
  15. }
  16. </style>
  17. </head>
  18. <body>
  19. <p class="one">一些文本。</p>
  20. <p class="two">更多的文本。</p>
  21. </body>
  22. </html>

设置元素的形状

本例演示如何设置元素的形状。此元素被剪裁到这个形状内,并显示出来。

  1. <html>
  2. <head>
  3. <style type="text/css">
  4. img
  5. {
  6. position:absolute;
  7. clip:rect(0px 50px 200px 0px)
  8. }
  9. </style>
  10. </head>
  11. <body>
  12. <p>clip 属性剪切了一幅图像:</p>
  13. <p><img border="0" src="/i/eg_bookasp.gif" width="120" height="151"></p>
  14. </body>
  15. </html>

Z-index

Z-index可被用于将在一个元素放置于另一元素之后。

  1. <html>
  2. <head>
  3. <style type="text/css">
  4. img.x
  5. {
  6. position:absolute;
  7. left:0px;
  8. top:0px;
  9. z-index:-1
  10. }
  11. </style>
  12. </head>
  13. <body>
  14. <h1>这是一个标题</h1>
  15. <img class="x" src="/i/eg_mouse.jpg" />
  16. <p>默认的 z-index 是 0。Z-index -1 拥有更低的优先级。</p>
  17. </body>
  18. </html>

Z-index

上面的例子中的元素已经更改了Z-index。

  1. <html>
  2. <head>
  3. <style type="text/css">
  4. img.x
  5. {
  6. position:absolute;
  7. left:0px;
  8. top:0px;
  9. z-index:1
  10. }
  11. </style>
  12. </head>
  13. <body>
  14. <h1>这是一个标题</h1>
  15. <img class="x" src="/i/eg_mouse.jpg" />
  16. <p>默认的 z-index 是 0。Z-index 1 拥有更高的优先级。</p>
  17. </body>
  18. </html>

相关页面

CSS 教程:CSS 定位

HTML DOM 参考手册:position 属性