美文网首页
四种常见的定位类型

四种常见的定位类型

作者: 郭先生_515 | 来源:发表于2019-02-19 13:42 被阅读0次

css常用的四种定位类型static、relative、absolute、fixed。要清楚的理解四种定位类型,首先要知道什么是文档流?

什么是文档流?

normal flow(普通流),元素在html中的排列方式——块级元素独占一行垂直排列,内联元素在行内从左至右依次排列

静态定位(static)

static定位,也叫静态定位,是html元素默认的定位方式,它遵循正常的文档流,占用文档空间,该定位方式下,top、right、bottom、left、z-index等属性是无效的。

相对定位(relative)

relative定位,也叫相对定位,根据原本在文档流中的位置进行偏移,遵循正常的文档流,但是top、right、left、bottom属性是生效的,最重要的是相对定位会占用原本的文档空间。

如下图所示,虽然红色方框相对虚线方框(原本位置)进行偏移,但是仍然占据原本的文档空间,所以绿色方框位置不会改变,并且红色方框的偏移会覆盖其他方框。

<style type="text/css">
    .red{position: relative; top: 20px; left: 20px;}
</style>
image.png

绝对定位(absolute)

absolute定位,也叫绝对定位,使用绝对定位的元素脱离文档流,只能根据祖先类元素(父类以上)进行定位,而且这个祖先类还必须是以position属性非static方式定位的。 举个栗子,若a元素使用绝对定位,它会从父类开始找起,寻找以position属性非static方式定位的祖先类元素,直到<html>标签为止。这里还需要注意的是,relative和static方式在最外层是以<body>标签作为定位原点,而absolute方式是以<html>标签作为定位原点。<html>和<body>元素相差8px左右的margin。

如下图所示,红色虚线框使用绝对定位,绿色虚线框使用相对定位。

<style type="text/css">
    .green{border: 2px dotted green; position: relative;}
    .red{border: 2px dotted red; position: absolute; top: 0px; left: 0px;}
</style>
image.png

绝对定位使元素的位置与文档流无关,因此不占据文档空间,这一点与相对定位不同。

为什么absoulte定位要加 top: 0px; left: 0px; 属性,是不是多此一举呢?

其实加上这两个属性是完全必要的,因为我们如果使用absolute和fixed定位的话,必须指定top、right、bottom、left属性中的至少一个,否则top、right、bottom、left属性会使用它们的默认值auto,这将导致对象遵从正常的HTML布局规则,在前一个对象之后立即被呈递,简单讲就是都变成relative,会占据文档空间,这点非常重要,很多人使用absolute定位后发现没有脱离文档流就是这个原因,这里要特别注意!

少了top、right、bottom、left属性不行,那如果我们多设了呢?例如,我们同时设置了top和bottom的属性值,那元素又该往哪偏移好呢?记住下面的规则:

如果top和bottom同时存在,那么只有top生效。
如果left和right同时存在,那么只有left生效。

固定定位(fixed)

fixed定位,又叫固定定位,它和absolute定位一样,脱离了文档流,并且能够根据top、right、left、bottom属性进行定位。但不同的是,fixed是根据窗口为原点进行偏移定位的,也就是说它不会根据滚动条的滚动而进行偏移。

相关文章

  • 四种常见的定位类型

    css常用的四种定位类型static、relative、absolute、fixed。要清楚的理解四种定位类型,首...

  • CSS

    有四种主要的定位类型需要我们了解: 静态定位(Static positioning)是每个元素默认的属性——它表示...

  • AFNetworking详解

    会话管理者 知识储备 -> post请求类型 一,常见的post请求类型 一共有四种: 1)application...

  • APP弹出框的类型

    app弹出框常见有四种类型,其中toast、snackbar属于非模态弹窗;dialog、actionbar属于模...

  • 指针

    Swift中也有专门的指针类型,这些都被定性为Unsafe不安全的,常见的又一下四种类型1.UnsafePonte...

  • 显示器接口VGA、DVI、HDMI、DP

    1.说明 对于显示器接口类型,常见的接口有VGA、DVI、HDMI、DP这四种,当然还有其他类型接口,本文主要介绍...

  • 常用的四种三栏布局

    1.浮动 2.定位 3.flex 4.表格布局 常见的就是这四种,还有其他的解决办法!

  • android 定位研究

    android 定位一般有四种方法,这四种方式分别是:GPS定位,WIFI定准,基站定位,AGPS定位. Andr...

  • #日更百字计划 Day22

    读《富定位,穷定位》1-9 四种财富优势类型 发电机型天才:擅长创意 火焰型天才:擅长人际交往 节奏型天才:擅长感...

  • Android 性能优化-Java引用类型

    Java引用类型分为强引用、软引用、弱引用、虚引用,本文对四种引用类型进行分析 强引用 强引用:日常开发中最常见的...

网友评论

      本文标题:四种常见的定位类型

      本文链接:https://www.haomeiwen.com/subject/xkwxyqtx.html