相对定位

- 定位指的就是将指定的元素摆放到页面的任意位置,通过定位可以任意的摆放元素。
- 通过position属性来设置元素的定位。
-可选值:

  1. static:默认值,元素没有开启定位;
  2. relative:开启元素的相对定位;
  3. absolute:开启元素的绝对定位;
  4. fixed:开启元素的固定定位(也是绝对定位的一种)。

当元素的position属性设置为relative时,则开启了元素的相对定位

  1. 当开启了元素的相对定位以后,而不设置偏移量时,元素不会发生任何变化;
  2. 相对定位是相对于元素在文档流中原来的位置进行定位;
  3. 相对定位的元素不会脱离文档流;
  4. 相对定位会使元素提升一个层级;
  5. 相对定位不会改变元素的性质,块还是块,内联还是内联。

position: relative;

当开启了元素的定位(position属性值是一个非static的值)时,可以通过left right top bottom四个属性来设置元素的偏移量。

  1. left:元素相对于其定位位置的左侧偏移量;
  2. right:元素相对于其定位位置的右侧偏移量;
  3. top:元素相对于其定位位置的上边的偏移量;
  4. bottom:元素相对于其定位位置下边的偏移量。

通常偏移量只需要使用两个就可以对一个元素进行定位,一般选择水平方向的一个偏移量和垂直方向的偏移量来为一个元素进行定位。

demo:

<!DOCTYPE html>
<html> <head>
<meta charset="utf-8" />
<title></title> <style type="text/css">
.box1 {
width: 200px;
height: 200px;
background-color: red;
}
/**
* 相对定位,相对原来位置向右100px
*/ .box2 {
width: 200px;
height: 200px;
background-color: yellow;
position: relative;
left: 100px;
} .box3 {
width: 200px;
height: 200px;
background-color: yellowgreen;
}
/**
* 相对定位,相对元素原来位置向右100px,向下100px
*/ .s1 {
position: relative;
width: 200px;
height: 200px;
background-color: yellow;
left: 100px;
top: 100px;
}
</style> </head> <body> <div class="box1"></div>
<div class="box2"></div>
<div class="box3"></div>
<span class="s1">我是一个span</span> </body> </html>

效果:


绝对定位

当position属性值设置为absolute时,则开启了元素的绝对定位。

绝对定位:

  1. 开启绝对定位,会使元素脱离文档流
  2. 开启绝对定位以后,如果不设置偏移量,则元素的位置不会发生变化
  3. 绝对定位是相对于离他最近的开启了定位的祖先元素进行定位的(一般情况,开启了子元素的绝对定位都会同时开启父元素的相对定位)
  4. 如果所有的祖先元素都没有开启定位,则会相对于浏览器窗口进行定位
  5. 绝对定位会使元素提升一个层级
  6. 绝对定位会改变元素的性质,内联元素变成块元素,块元素的宽度和高度默认都被内容撑开

demo:

<!DOCTYPE html>
<html> <head>
<meta charset="UTF-8">
<title></title> <style type="text/css">
.box1 {
width: 200px;
height: 200px;
background-color: red;
}
/**
* 绝对定位是相对于离他最近的开启了定位的祖先元素进行定位的
* box2的祖先元素box4设置相对定位,因此box2的绝对定位是相对box4来进行定位的
*/ .box2 {
width: 200px;
height: 200px;
background-color: yellow;
position: absolute;
left: 100px;
top: 100px;
}
/**
* 如果所有的祖先元素都没有开启定位,则会相对于浏览器窗口进行定位
*/ .box3 {
width: 200px;
height: 200px;
background-color: yellowgreen;
position: absolute;
left: 100px;
top: 100px;
} .box4 {
width: 300px;
height: 300px;
background-color: orange;
/*开启box4的相对定位*/
position: relative;
}
/**
* 绝对定位会改变元素的性质,内联元素变成块元素,块元素的宽度和高度默认都被内容撑开,如果不设置,宽高为内容大小
*/ .s1 {
width: 100px;
height: 100px;
background-color: yellow;
position: absolute;
}
</style> </head> <body> <div class="box1">
box1
</div>
<div class="box5">
box5
<div class="box4">
box4
<div class="box2">
box2
</div>
</div>
</div> <div class="box3">box3</div> <span class="s1">span</span>
</body> </html>

效果:


固定定位

当元素的position属性设置fixed时,则开启了元素的固定定位,固定定位也是一种绝对定位,它的大部分特点都和绝对定位一样。
不同的是:

  1. 固定定位永远都会相对于浏览器窗口进行定位;
  2. 固定定位会固定在浏览器窗口某个位置,不会随滚动条滚动。

IE6不支持固定定位。

demo:

<!DOCTYPE html>
<html> <head>
<meta charset="UTF-8">
<title></title> <style type="text/css">
.box1 {
width: 200px;
height: 200px;
background-color: red;
}
/**
* 页面滚动,box2依然不动,固定在左上角
*/ .box2 {
width: 200px;
height: 200px;
background-color: yellow;
position: fixed;
left: 0px;
top: 0px;
} .box3 {
width: 200px;
height: 200px;
background-color: yellowgreen;
} .box4 {
width: 300px;
height: 300px;
background-color: orange;
}
</style> </head> <body style="height: 5000px;"> <div class="box1">box1</div>
<div class="box4">box4
<div class="box2">box2</div>
</div>
<div class="box3">box3</div>
</body> </html>

效果:

其中box2固定在左上角位置,不随滚轴移动而移动

代码已经提交到github上面,可以pull下来运行:

项目地址:

https://github.com/soyoungboy/htmlCssStudy

相对定位:

https://github.com/soyoungboy/htmlCssStudy/blob/master/HelloHBuilder/RelativePosition.html

绝对定位:

https://github.com/soyoungboy/htmlCssStudy/blob/master/HelloHBuilder/AbsolutePosition.html

固定定位:

https://github.com/soyoungboy/htmlCssStudy/blob/master/HelloHBuilder/FixedPosition.html

前端学习 -- Html&Css -- 相对定位 绝对定位 固定定位的更多相关文章

  1. 前端CSS - 相对定位,绝对定位,固定定位

    前端CSS - 相对定位,绝对定位,固定定位 1.1 相对定位 position:relative 相对定位,就是微调元素位置的.让元素相对自己原来的位置,进行位置的微调. 也就是说,如果一个盒子想进 ...

  2. 理解CSS相对定位和固定定位

    × 目录 [1]相对定位 [2]固定定位 前面的话 一般地,说起定位元素是指position不为static的元素,包括relative.absolute和fixed.前面已经详细介绍过absolut ...

  3. 前端学习笔记--CSS布局--文件流定位

    1.概述 2.文档流定位:从上到下,从左到右 代码: <!DOCTYPE html> <html lang="en"> <head> <m ...

  4. 前端学习 之 CSS(二)

    五:继承性和层叠性 css有两大特性,即继承性和层叠性. 1. 继承性 面向对象语言都会存在继承的概念,在面向对象语言中,继承的特点:继承了父类的属性和方法.那么我们现在主要研究css,css就是在设 ...

  5. 前端学习:CSS的学习总结(图解)

    前端学习:CSS的学习总结(图解) CSS代码笔记 CSS简介 css的引入方式和书写规范 CSS选择器 CSS属性 CSS盒子模型 CSS的定位

  6. web前端学习笔记(CSS盒子的定位)

    相对定位 使用相对定位的盒子的位置常以标准流的排版方式为基础,然后使盒子相对于它在原本的标准位置偏移指定的距离.相对定位的盒子仍在标准流中,它后面的盒子仍以标准流方式对待它.      使用relat ...

  7. HTML定位——绝对定位和相对定位、固定定位

    1.绝对定位 绝对定位指的是通过规定HTML元素在水平和垂直方向上的位置来固定元素,基于绝对定位的元素不会占据空间. 绝对定位的位置声明是相对于已定位的并且包含关系最近的祖先元素.如果当前需要被定为的 ...

  8. 前端学习 之 CSS(三)

    九:浮动 浮动是css里面布局最多的一个属性,也是很重要的一个属性. float:表示浮动的意思. 属性值: none: 表示不浮动,默认 left: 表示左浮动 right:表示右浮动 例: htm ...

  9. 前端学习之CSS

    CSS介绍 CSS(Cascading Style Sheet, 层叠样式表)定义如何显示HTML元素, 给HTML设置样式, 让它更加美观. 当浏览器读到一个样式表, 它就会按照这个样式表来对文档进 ...

随机推荐

  1. c# 限制同时启动多个实例程序运行

    using System; using System.Collections.Generic; using System.Text; using System.Diagnostics; using S ...

  2. 20155204 2016-2017-2 《Java程序设计》第1周学习总结

    20155204 2016-2017-2 <Java程序设计>第1周学习总结 一.学习考核方式,理解成绩构成 首先是100分的构成,主要分为周考的总计60,实验的15分,团队项目(博客报告 ...

  3. 20155218《网络对抗》Exp2 后门原理与实践

    20155218<网络对抗>Exp2 后门原理与实践 常用后门工具实践 1.Windows获得Linux Shell: 在Windows下,先使用ipconfig指令查看本机IP,使用nc ...

  4. 查看Oracle数据库中的,已经连接好的..当前用户状况

    参考: http://stackoverflow.com/questions/1043096/how-to-list-active-open-connections-in-oracle 以sys身份连 ...

  5. JavaScript实现选项卡(三种方法)

    本文实例讲述了js选项卡的实现方法. 一.html代码: <div id="div1"> <input class="active" type ...

  6. 算法练习-002-返回一个set数组

    题目描述: 写一个函数,它的作用是接受一个整数(假设为num),返回一个数组,数组的长度为num, 数组中的内容为随机的0至(num-1)的值,并且不能重复.比如num为5的话,数组可能是[1,0,3 ...

  7. Redis简介、安装、配置、启用学习笔记

    前一篇文章有介绍关系型数据库和非关系型数据库的差异,现在就来学习一下用的较广的非关系型数据库:Redis数据库 Redis 简介 Redis 是完全开源免费的,遵守BSD协议,是一个高性能的key-v ...

  8. 英特尔帮助优化 Epic 的《堡垒之夜》* 和 Unreal Engine*

    您可能知道,Epic 的游戏<堡垒之夜>是 Unreal Engine* 技术的绝佳示例,<堡垒之夜>的开发团队正不断改进游戏,增加支持平台的数量并将信息反馈给引擎.为此,英特 ...

  9. 搭建个人博客 github+hexo

    其实相关的教程网上有很多很多,不过就是很多很多,而且技术大神们每个人都写得不一样啊喂,为什么我明明就是一步一步按照教程来的还是有那么多乱七八糟的错?...所以我决定写此篇记录一下我搭建博客的过程以及我 ...

  10. Java 8 新特性---------Stream

    Java 8 API添加了一个新的抽象称为流Stream,可以让你以一种声明的方式处理数据. Stream使用一种类似用SQL语句从数据库查询数据的直观方式来提供一种对Java集合运算和表达的高阶抽象 ...