position属性详解

  • 文档流

1、html中的布局方式分为三种:

标准流(顺序布局):因为html中的元素大体可以分为两大类(a:块级元素:div .H1-H6. table表格  有序级无序列表   P段落;b: 内联元素:a  span img input)

两者之间的区别:a.块元素总是独占一行的,而内联元素是占相邻元素的同一行,当内容超出了宽度的时候才会被挤到下一行

用代码验证标准流的特性:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>标准流</title> <style>
.test{
width: 100px;
height: 100px;
background: red;
border:1px solid #FFF;
}
</style>
</head>
<body>
<div class="test"></div>
<div class="test"></div>
<div class="test"></div>
<div class="test"></div>
<span>文字1</span>
<span>文字2</span>
<span>文字3</span> </body>
</html>

效果如图

说明:因为 div为块级元素,所以每一个占据一行,要想占同一行,可用float,  span为内联元素,全部占据同一行

2、浮动:以后添加

3、定位布局方式:定位布局是为了让元素脱离正常的标准流布局,决定了以什么 方式进行定位。

  • static:是默认值,元素按照正常的标准流进行定位
  • position-relative:仍然是出于正常的文档流中,但是我们可以通过top  left right bottom来改变元素的位置

  • 说明:红色和蓝色两个区域本来是同样大小的结果蓝色都使用了相对定位的时候,蓝色的覆盖在了红色的上面,这说明后定义的relative >  先定义的
  • 问题2:在相对定位中是如何通过top right left bottom来中控制元素的移动的
  • <!DOCTYPE html>
    <html lang="en">
    <head>
    <meta charset="UTF-8">
    <title>relative</title>
    <style>
    .test1{
    width: 100px;
    height: 100px;
    background: red;
    position: relative;
    left: 10px; //当改变这里的参数会发现(top, left)是以左上角为原点以第四现象为正轴移动
    bottom:50px; //(right, bottom)是以左上角为原点第二现象为正轴移动
  • </style></head><body><div class="test1"></div></body></html>
  • 讨论:改变top left bottom right各有什么变化:这里就不一一给出结果了,经过测试可以发现:left  top:是以左上角的顶点为原点,第四象限的方向为正方向;right  top:是以右上角的顶点为原点,第三象限的方向为正方向;left bottom:是以左下角的方向为原点,第一象限的方向为正方向;right  bottom:是以右下角的方向为原点,第二象限的方向为正方向。
  • position-absolute:当这个配合 top left 等属性的时候将会脱离正常的文档流,并且在网页的任何时候都是可以定位的,同样是后写的元素会覆盖先写到元素。
  • <!DOCTYPE html>
    <html lang="en">
    <head>
    <meta charset="UTF-8">
    <title>relative</title> <style>
    *{
    margin: 0;
    padding: 0;
    }
    .test{
    width: 100px;
    height: 100px;
    background: red;
    position: absolute; } </style>
    </head>
    <body> <div class="test"></div>
    </body>
    </html>

    我们通过控制台可以看到,原来设定的宽*高=100*100  而现在元素已经没有了高度,说明此时设定了绝对定位以后,元素已经脱离了正常的文档流。

  • 当我们在增加一个div之后
  • <!DOCTYPE html>
    <html lang="en">
    <head>
    <meta charset="UTF-8">
    <title>relative</title> <style>
    *{
    margin: 0;
    padding: 0;
    }
    .test1{
    width: 100px;
    height: 100px;
    background: blue;
    }
    .test{
    width: 100px;
    height: 100px;
    background: red;
    position: absolute; } </style>
    </head>
    <body>
    <div class="test1"></div>
    <div class="test"></div> </body>
    </html>

    因为没有对其设置top bottom属性,所以这两个元素依然是按照标准的定位流进行布局。

  • 一旦设置了top left:(这里自己添加)可见此时以不再按照标准流的布局方式排
  • position-fixed:1)会脱离正常的文档流,可以在窗口的任何地方布局。2)不会随着滚动条移动
  • <!DOCTYPE html>
    <html lang="en">
    <head>
    <meta charset="UTF-8">
    <title>relative</title>
    <style>
    body{
    height: 3000px;
    } .test{
    width: 100px;
    height: 100px;
    background: red;
    position: fixed;
    top:0px;
    left: 0px;
    } </style>
    </head>
    <body> <div class="test"></div>
    </body>
    </html>

    当我们滚动滚动条的时候会发现,该元素并不会随着滚动条移动。(这里没有贴样式)

  • 3)固定定位与绝对定位的区别
    <!DOCTYPE html>
    <html lang="en">
    <head>
    <meta charset="UTF-8">
    <title>relative</title> <style>
    .test{
    width: 100px;
    height: 100px;
    background: red;
    position: fixed;
    top:100px;
    left: 100px; }
    .per{
    width: 300px;
    height: 300px;
    background: blue;
    position: absolute;
    left: 300px;
    top: 300px;
    } </style>
    </head>
    <body>
    <div class="per">
    <div class="test"></div> </div> </body>
    </html>

  • 可以看到红色依然是按照左上角进行定位的,并不是按照父元素定位的,这是固定定位与绝对定位的区别
  • position-inherit:继承,相应的元素可以继承父元素的定位属性
  • 没有对父元素设定定位属性
  • <!DOCTYPE html>
    <html lang="en">
    <head>
    <meta charset="UTF-8">
    <title>relative</title> <style> *{
    margin: 0;
    padding: 0;
    }
    .per{
    width: 300px;
    height: 300px;
    background: red;
    position: relative; }
    .son{
    width: 100px;
    height: 100px;
    background: blue;
    position:inherit;
    top:100px;
    left: 100px; } </style>
    </head>
    <body>
    <div class="per">
    <div class="son"></div> </div> </body>
    </html>

  • 此时可以看到子元素依然是按照窗口的定位
  • 一旦将父元素设置了相对定位

css 中 position属性的更多相关文章

  1. 深入理解css中position属性及z-index属性

    深入理解css中position属性及z-index属性 在网页设计中,position属性的使用是非常重要的.有时如果不能认识清楚这个属性,将会给我们带来很多意想不到的困难. position属性共 ...

  2. CSS中Position属性

    也许你看到这个标题觉得很简单,确实这是一篇关于CSS中Position属性基础知识的文章,但是关于Position的一些细节也许你不了解. 1.简介 position有五个属性: static | r ...

  3. CSS中Position属性static、absolute、fixed、relative

    在html中网页可以看成一个立体的空间,一个完整的页面是由很多个页面堆积形成的,如下图所示   CSS中Position属性有四个可选值,它们分别是:static.absolute.fixed.rel ...

  4. 深入理解css中position属性及z-index属性 https://www.cnblogs.com/zhuzhenwei918/p/6112034.html

    深入理解css中position属性及z-index属性 请看出处:https://www.cnblogs.com/zhuzhenwei918/p/6112034.html 在网页设计中,positi ...

  5. css中position属性(absolute|relative|static|fixed)概述及应用

    position属性的相关定义: static:无特殊定位,对象遵循正常文档流; relative:对象遵循正常文档流; absolute:对象脱离正常文档流 fixed:对象脱离正常文档流 我们先来 ...

  6. 【转】CSS中position属性( absolute | relative | static | fixed )详解

    我们先来看看CSS3 Api中对position属性的相关定义: static:无特殊定位,对象遵循正常文档流.top,right,bottom,left等属性不会被应用. relative:对象遵循 ...

  7. CSS中position属性( absolute | relative | static | fixed )详解

    我们先来看看CSS3 Api中对position属性的相关定义: static:无特殊定位,对象遵循正常文档流.top,right,bottom,left等属性不会被应用. relative:对象遵循 ...

  8. CSS中position属性 (absolute,relative,static,fixed)

    只要position的属性值设置的不是默认的值则定位的元素都将脱离文档流 1.static是position的默认的值,按照正常的文档流进行排版,设置了该属性值得元素的top,left属性均不起作用. ...

  9. 转:深入理解css中position属性及z-index属性

    原文链接:https://www.cnblogs.com/zhuzhenwei918/p/6112034.html static定位是HTML元素的默认值,即没有定位,元素出现在正常的流中,因此,这种 ...

随机推荐

  1. window.location.href ie 不兼容问题

    今天再做项目演示的时候,用的是ie浏览器报错404,项目都运行好久了,第一次用ie就这样了悲剧,贴下解决方法吧 function getContextPath() { var pathName = d ...

  2. Cherry.chen window.clipboardData实现剪切板操作总结 (好像只有ie好用)

    window.clipboardData的作用是在页面上将需要的东西复制到剪贴板上,提供了对于预定义的剪贴板格式的访问,以便在编辑操作中使用. 三个方法 (1)clearData(sDataForma ...

  3. 开始一个简单的ASP.NET Web API 2 (C#)

    创建一个Web API 项目 在本教程中,你将使用ASP.NET Web API 来创建一个web API 并返回产品列表. 网页前端使用jQuery 显示结果. 选择ASP.NET Web Appl ...

  4. Row_Number() over()

    分页 ROW_NUMBER() OVER (order by ID) 是先把ID列排序,再为排序以后的每条ID记录返回一个序号.

  5. 基准对象object中的基础类型----元组 (五)

    object有如下子类: CLASSES object basestring str unicode buffer bytearray classmethod complex dict enumera ...

  6. 洛谷P1107[BJWC2008]雷涛的小猫题解

    题目 这个题可以说是一个很基础偏中等的\(DP\)了,很像\(NOIpD1T2\)的难度,所以这个题是很好想的. 简化题意 可以先简化一下题意,这个题由于从上面向下调和从下向上爬都是一样的,所以我们就 ...

  7. 大学实验3指导:利用单链表实现A-B

    实验目的:深入理解单链表的建立及操作 实验内容: 1.建立单链表A与B 2.实现主要的函数,查找.插入.删除等 3.实现操作A-B 步骤1:包含必要的函数库,对结构体LNode中的抽象数据类型Elem ...

  8. Win10报错0x800f0906

    在安装适用于Linux的Windows子系统(Beta)的时候,有选中开发人员模式这一步设置->更新和安全->针对开发人员->选中开发人员模式 如果报错0x800f0906 那是因为 ...

  9. IntegrityError at /admin/users/userprofile/add/ (1452, 'Cannot add or update a child row: a foreign key constraint fails (`mxonline`.`django_admin_log`, CONSTRAINT `django_admin_log_user_id_c564eba6_

    报错现象 在执行 django 后台管理的时候添加数据导致 1452 错误 报错代码 IntegrityError at /admin/users/userprofile/add/ (1452, 'C ...

  10. MT【311】三角递推数列

    已知数列$\{a_n\}$满足$a_1=\dfrac{1}{2},a_{n+1}=\sin\left(\dfrac{\pi}{2}a_n\right),S_n$ 为$\{a_n\}$的前$n$项和,求 ...