zoukankan      html  css  js  c++  java
  • CSS定位属性

    定位

    position

    语法:

    position:static | relative | absolute | fixed | sticky

    默认值:static

    适用于:除display属性定义为table-column-group | table-column之外的所有元素

    继承性:无

    动画性:否

    计算值:指定值

    媒体:视觉

    取值:

    • static: 对象遵循常规流。此时4个定位偏移属性不会被应用。
    • relative: 对象遵循常规流,并且参照自身在常规流中的位置通过toprightbottomleft这4个定位偏移属性进行偏移时不会影响常规流中的任何元素。
    • absolute: 对象脱离常规流,此时偏移属性参照的是离自身最近的定位祖先元素,如果没有定位的祖先元素,则一直回溯到body元素。盒子的偏移位置不影响常规流中的任何元素,其margin不与其他任何margin折叠。
    • fixed: 与absolute一致,但偏移定位是以窗口为参考。当出现滚动条时,对象不会随着滚动。
    • sticky: 对象在常态时遵循常规流。它就像是relativefixed的合体,当在屏幕中时按常规流排版,当卷动到屏幕外时则表现如fixed。该属性的表现是现实中你见到的吸附效果。(CSS3)

    说明:

    用于指定一个元素在文档中的定位方式

    • position的值为非static时,其层叠级别通过z-index属性定义。
    • 绝对定位的元素,在top,right,bottom,left属性未设置时,会紧随在其前面的兄弟元素之后,但在位置上不影响常规流中的任何元素。
    • 对应的脚本特性为position

    z-index

    语法:

    z-index: auto | 整数

    默认值:auto

    适用于:定位元素。即定义了position为非static的元素

    继承性:无

    动画性:当值为整数时

    计算值:指定的值

    媒 体:视觉

    取值:

    • auto: 元素在当前层叠上下文中的层叠级别是0。元素不会创建新的局部层叠上下文,除非它是根元素。
    • 整数:用整数值来定义堆叠级别。可以为负值。

    说明:

    定义一个元素在文档中的层叠顺序

    • z-index用于确定元素在当前层叠上下文中的层叠级别,并确定该元素是否创建新的局部层叠上下文。

    • 每个元素层叠顺序由所属的层叠上下文和元素本身的层叠级别决定(每个元素仅属于一个层叠上下文)。

    • 同一个层叠上下文中,层叠级别大的显示在上面,反之显示在下面。

    • 同一个层叠上下文中,层叠级别相同的两个元素,依据它们在HTML文档流中的顺序,写在后面的将会覆盖前面的。

    • 不同层叠上下文中,元素的显示顺序依据祖先的层叠级别来决定,与自身的层叠级别无关。

    • z-index未定义或者值为auto时,在IE6,7下会创建新的局部层叠上下文,而在高级浏览器中,按照规范不产生新的局部层叠上下文,如下例:

      div {
      	position: relative;
      }
      p {
      	position: absolute;
      }
      .a {
      	background: #f00;
      	z-index: 10;
      }
      .b {
      	background: #0ff;
      	z-index: 3;
      }
      
      <div class="test">
      	<p class="a">asdas</p>
      </div>
      <div class="test2">
      	<p class="b">asdas</p>
      </div>
      

      细心的你会发现上述代码在IE6,7下的呈现与高级浏览器下不同。.test1和.test2未设置z-index,在高级浏览器下不会产生新的局部层叠上下文,也就是说它们的子元素没有被新的局部层叠上下文包裹,那么它们的子元素就处在同一个层叠上下文中,可以直接通过自身的层叠级别来决定显示顺序,所以结果是.a 覆盖了.b,因为.a的层叠级别比.b高;而在IE6,7下,.test1和.test2会产生新的局部层叠上下文,即它们的子元素被新的局部层叠上下文包裹,于是子元素显示顺序只能依赖.test1和.test2层叠级别来确定。所以结果是.b 覆盖了.a,因为.b的父元素.test2在HTML文档流中排在.test1之后,后来者居上覆盖前者。

    top

    语法:

    top: auto | 整数值 | 百分比

    默认值:auto

    适用于:定位元素。即定义了position为非static的元素

    继承性:无

    动画性:当值为 整数值|百分比 时

    计算值:当position为static时,计算值是auto
    relative时,如果topbottom都是auto,则它们的计算值是0;如果topbottom其中一个为auto,则auto相当于另一个的负值,即top = -bottom;如果topbottom的值都不为auto,则忽略bottom
    否则在其它情况下,当指定值为整数值时,计算值为指定值,当指定值为百分比时,计算值为计算后的绝对值。除去这些情况,都为auto

    媒 体:视觉

    取值

    • auto: 无特殊定位,根据HTML定位规则在文档流中分配
    • 整数值: 用长度值来定义距离顶部的偏移量。可以为负值。
    • 百分比: 用百分比来定义距离顶部的偏移量。百分比参照包含块的高度。可以为负值。

    说明:

    定义了元素的上外边距边界与其包含块上边界之间的偏移

    • 该属性用来指定盒子参照相对物顶边界向下偏移。相对定位元素的相对物是自身,绝对定位和居中定位元素是从包含块的padding边界开始计算偏移值
    • 对应的脚本特性为top

    语法:

    right:auto | 整数值 | 百分比

    默认值:auto

    适用于:定位元素。即定义了position为非static的元素

    继承性:无

    动画性:当值为 整数值|百分比 时

    计算值:当position为static时,计算值是auto
    relative时,如果rightleft都是auto,则它们的计算值是0;如果rightleft其中一个为auto,则auto相当于另一个的负值,即left = -right;如果rightleft的值都不为auto,则忽略right
    否则在其它情况下,当指定值为整数值时,计算值为指定值,当指定值为百分比时,计算值为计算后的绝对值。除去这些情况,都为auto

    媒 体:视觉

    取值:

    • auto: 无特殊定位,根据HTML定位规则在文档流中分配
    • 整数值: 用长度值来定义距离右边的偏移量。可以为负值。
    • 百分比: 用百分比来定义距离右边的偏移量。百分比参照包含块的宽度。可以为负值。

    说明:

    定义了元素的右外边距边界与其包含块右边界之间的偏移

    • 该属性用来指定盒子参照相对物右边界向左偏移。相对定位元素的相对物是自身,绝对定位和居中定位元素是从包含块的padding边界开始计算偏移值
    • 对应的脚本特性为right

    bottom

    语法:

    bottom: auto | 整数值 | 百分比

    默认值:auto

    适用于:定位元素。即定义了position为非static的元素

    继承性:无

    动画性:当值为整数值 | 百分比时

    计算值:当position为static时,计算值是auto
    relative时,如果topbottom都是auto,则它们的计算值是0;如果topbottom其中一个为auto,则auto相当于另一个的负值,即top = -bottom;如果topbottom的值都不为auto,则忽略bottom
    否则在其它情况下,当指定值为整数值时,计算值为指定值,当指定值为百分比时,计算值为计算后的绝对值。除去这些情况,都为auto

    媒 体:视觉

    取值:

    • auto: 无特殊定位,根据HTML定位规则在文档流中分配

    • 整数值:

      用长度值来定义距离底部的偏移量。可以为负值。

    • 百分比:

      用百分比来定义距离底部的偏移量。百分比参照包含块的高度。可以为负值。

    说明:

    定义了元素的底外边距边界与其包含块底边界之间的偏移

    • 该属性用来指定盒子参照相对物底边界向上偏移。相对定位元素的相对物是自身,绝对定位和居中定位元素是从包含块的padding边界开始计算偏移值
    • 对应的脚本特性为bottom

    left

    语法:

    left: auto | 整数值 | 百分比

    默认值:auto

    适用于:定位元素。即定义了position为非static的元素

    继承性:无

    动画性:当值为整数值 | 百分比时

    计算值:当positionstatic时,计算值是auto
    relative时,如果rightleft都是auto,则它们的计算值是0;如果rightleft其中一个为auto,则auto相当于另一个的负值,即left = -right;如果rightleft的值都不为auto,则忽略right
    否则在其它情况下,当指定值为整数值时,计算值为指定值,当指定值为百分比时,计算值为计算后的绝对值。除去这些情况,都为auto

    媒 体:视觉

    取值:

    • auto: 无特殊定位,根据HTML定位规则在文档流中分配

    • 整数值:

      用长度值来定义距离左边的偏移量。可以为负值。

    • 百分比:

      用百分比来定义距离左边的偏移量。百分比参照包含块的宽度。可以为负值。

    说明:

    定义了元素的左外边距边界与其包含块左边界之间的偏移

    • 该属性用来指定盒子参照相对物左边界向右偏移。相对定位元素的相对物是自身,绝对定位和居中定位元素是从包含块的padding边界开始计算偏移值
    • 对应的脚本特性为left

    clip

    语法:

    clip:auto |

    :rect(数字|auto 数字|auto 数字|auto 数字|auto)

    默认值:auto

    适用于:绝对定位元素

    继承性:无

    动画性:当值为

    计算值:指定的值

    媒 体:视觉

    取值:

    auto:

    对象无剪切

    rect(数字|auto 数字|auto 数字|auto 数字|auto):

    依据上-右-下-左的顺序提供自对象左上角为(0,0)坐标计算的四个偏移数值,其中任一数值都可用auto替换,即此边不剪切。

    上-左 方位的裁剪:从0开始剪裁直到设定值,即 上-左 方位的auto值等同于0;

    右-下 方位的裁剪:从设定值开始剪裁直到最右边和最下边,即 右-下 方位的auto值为盒子的实际宽度和高度;

    示例:clip: rect(auto 50px 20px auto)

    说明:上边不剪切,右边从左起第50个像素开始剪切直至最右边,下边从上起第20个像素开始剪切直至最底部,左边不剪切

    说明:

    定义了元素的哪一部分是可见的。区域外的部分是透明的

    • 这个属性将被废弃,推荐使用 clip-path 代替,在过渡阶段,仍然会存在一段时间。
    • 必须将position的值设为absolute或者fixed,此属性方可使用。
    • 对应的脚本特性为clip

    示例:

    <!DOCTYPE html>
    <html lang="ZH-CN">
    <head>
    <meta charset="utf-8" />
    <title>clip_CSS</title>
    <style>
    .test {
    	position: absolute;
    	height: 50px;
    	line-height: 50px;
    	clip: rect(0 auto 35px 10px);
    	background: #eee;
    }
    </style>
    </head>
    <body>
    <div class="test">看看被剪切后的效果</div>
    </body>
    </html>
    
  • 相关阅读:
    Java(类与对象)
    Java(数组)动手动脑
    《大道至简》第一章阅读笔记
    Java(接口与继承)动手动脑
    《大道至简》第二章阅读笔记
    Java(String)
    Java动手动脑
    Java程序设计笔记
    控制结构(1)判断控制
    MySQL Cluster 详细配置文件(config.ini)
  • 原文地址:https://www.cnblogs.com/lx-pricking/p/13192205.html
Copyright © 2011-2022 走看看