相对定位

- 定位指的就是将指定的元素摆放到页面的任意位置,通过定位可以任意的摆放元素。
- 通过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. laravel 5.5 《电商实战 》辅助函数

    Laravel 提供了很多 辅助函数,有时候我们也需要创建自己的辅助函数. 这里介绍了 tinker,一个laravel内置的php交互式控制台,方便调试php代码 php artisan tinke ...

  2. 20155323刘威良 网络对抗 Exp2 后门原理与实践

    20155323 刘威良<网络攻防>Exp2后门原理与实践 实验内容 (1)使用netcat获取主机操作Shell,cron启动 (0.5分) (2)使用socat获取主机操作Shell, ...

  3. SVD(奇异值分解)Python实现

    注:在<SVD(奇异值分解)小结 >中分享了SVD原理,但其中只是利用了numpy.linalg.svd函数应用了它,并没有提到如何自己编写代码实现它,在这里,我再分享一下如何自已写一个S ...

  4. EZ 2018 05 01 NOIP2018 模拟赛(十一)

    莫名其妙暴涨Rating 其实题目都挺好挺简单的,但是越简单就越容易ZZ 不理解问什么第一题这么多人找环 不过T2是真心细节题,T3太难了 题目戳这里 T1 仔细分析题意发现那个交换规则就是废话,如果 ...

  5. LoRa---她的简介和她的专业术语

    LoRa是LPWAN(低功耗广域网)通信技术的一种,其作用距离超过 15 公里,连接节点可达 100 万个.低功耗与长距离极限的组合可将最大数据速率提升至每秒 50千比特(Kbps). LoRa 是  ...

  6. Eclipse中Hadoop插件配置

    Eclipse中Hadoop插件DFS配置 http://www.cnblogs.com/xia520pi/archive/2012/05/20/2510723.html

  7. opencv配置(转)

    1. 下载安装Opencv,去官网http://opencv.org/即可下载最新版本的Opencv,此处用的是Opencv 2.4.10 安装时傻瓜式的,最新版本的安装就是相当于解压到你指定的安装目 ...

  8. SSRS配置2:加密管理

    在初始化Reporting Service时,SSRS会自动创建数据库[ReportServer],用于存储报表元数据,报表订阅,以及凭证(Credential)和连接信息等身份验证信息,身份验证数据 ...

  9. 前端示例MVC网站

    前端示例MVC网站 ASP.NET Zero 包含了一个公共web站点的前端页面和一个登陆页面.当您第一次运行项目的时候可以看到,如下图所示: 该前端网站有两个页面,一个是主页和关于我们.这些页面的内 ...

  10. Redux系列01:从一个简单例子了解action、store、reducer

    其实,redux的核心概念就是store.action.reducer,从调用关系来看如下所示 store.dispatch(action) --> reducer(state, action) ...