定位是一种更加高级的布局手段,通过定位可以将一个元素摆放到页面的任意位置,使用position属性来设置定位。
知识点学习
1、定位的简介
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
div{
font-size: 60px;
}
.box1{
width: 200px;
height: 200px;
background-color: wheat;
}
.box2{
width: 200px;
height: 200px;
background-color:green;
/*
定位(position)
- 定位是一种更加高级的布局手段
- 通过定位可以将一个元素摆放到页面的任意位置
- 使用position属性来设置定位
可选值:
static 默认值 没有开启定位
relative 开启相对定位
absolute 开启绝对定位
fixed 开启固定定位
sticky 开启粘滞定位
- 相对定位:
- 设置 relative ,开启相对定位
- 相对定位的特点:
1、元素开启相对定位以后,如果不设置偏移量元素不会发生任何变化
2、相对于原来文档流的位置
3、会提升元素的层级
4、相对定位不会使元素脱离文档流
5、相对定位不会改变元素的性质
- 偏移量(offset)
- 当元素开启了定位以后,可以通过偏移量来设置元素的位置
top 距离顶部的距离
bottom 距离底部的距离
left
right
*/
position: relative;
top: -200px;
left: 200px;
}
.box3{
width: 200px;
height: 200px;
background-color: red;
}
</style>
</head>
<body>
<div class="box1">1</div>
<div class="box2">2</div>
<div class="box3">3</div>
</body>
</html>
2、绝对定位
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
div{
font-size: 60px;
}
.box1{
width: 200px;
height: 200px;
background-color: wheat;
}
.box2{
width: 200px;
height: 200px;
background-color:green;
/*
绝对定位:
- 当元素 position 属性值设置为 absolute 开启绝对定位
- 绝对定位的特点:
1、开启绝对定位以后,如果不设置偏移量元素的位置不会发生变化
2、开启绝对定位以后,元素会从文档流中脱离
3、会改变元素的性质,行内变成块,块的宽高被内容撑开
4、会提升元素的层级
5、绝对定位元素是相对于包含快进行定位的
包含块:
-正常情况下:
包含块就是当前元素最近的祖先 块 元素
- 绝对定位的包含块:
包含块就是离它最近的开启了定位的祖先元素
如果所有的祖先元素都没有开启定位,那么根据根元素
*/
position: absolute;
top: 0;
left: 0;
}
.box3{
width: 200px;
height: 200px;
background-color: red;
}
.box4{
width: 400px;
height: 400px;
background-color: rgb(119, 0, 255);
position: relative;
}
.box5{
width: 300px;
height: 300px;
background-color: rgb(255, 0, 179);
position: relative;
}
</style>
</head>
<body>
<div class="box1">1</div>
<div class="box4">
4
<div class="box5">
5
<div class="box2">2</div>
</div>
</div>
<div class="box3">3</div>
</body>
</html>
3、固定定位
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
div{
font-size: 60px;
}
.box1{
width: 200px;
height: 200px;
background-color: wheat;
}
.box2{
width: 200px;
height: 200px;
background-color:green;
/*
固定定位:
- 也是一种绝对定位,大部分特点和绝对定位一样
- 唯一不同的是,固定定位永远参考浏览器的视口进行定位
不会随着窗口的滚动而滚动
- 小广告
*/
position: fixed;
left: 0;
top: 0;
}
.box3{
width: 200px;
height: 200px;
background-color: red;
}
.box4{
width: 400px;
height: 400px;
background-color: rgb(119, 0, 255);
position: relative;
}
.box5{
width: 300px;
height: 300px;
background-color: rgb(255, 0, 179);
}
</style>
</head>
<body>
<div class="box1">1</div>
<div class="box4">
4
<div class="box5">
5
<div class="box2">2</div>
</div>
</div>
<div class="box3">3</div>
</body>
</html>
4、粘滞定位
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>导航条</title>
<style>
body{
height: 3000px;
}
*{
margin: 0;
padding: 0;
}
ul{
margin: 0;
padding: 0;
/* 去除项目符号 */
list-style: none;
margin-left: 20px;
}
.nav{
width: 1205px;
height: 48px;
background-color: #E8E7E3;
margin: 100px auto;
/*
粘滞定位:
- 和相对定位的特点基本一致,不同的是粘滞定位可以将一个元素到达某个位置的时候不动
*/
position: sticky;
top: 0;
}
.nav li{
float: left;
line-height: 48px;
}
.nav a{
display: block;
text-decoration: none;
color: #777777;
font-size: 18px;
padding: 0 39px;
}
.nav a:hover{
background-color: #3f3f3f;
color: #e8e7e3;
}
</style>
</head>
<body>
<!-- 创建导航条的结构 -->
<ul class="nav">
<li>
<a href="#">HTML/CSS</a>
</li>
<li>
<a href="#">Browser Side</a>
</li>
<li>
<a href="#">Server Side</a>
</li>
<li>
<a href="#">Programming</a>
</li>
<li>
<a href="#">XML</a>
</li>
<li>
<a href="#">Web Building</a>
</li>
<li>
<a href="#">Reference</a>
</li>
</ul>
</body>
</html>
5、绝对定位元素的布局
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
.box1{
width: 500px;
height: 500px;
background-color: aqua;
position: relative;
}
.box2{
width: 100px;
height: 100px;
background-color: bisque;
position: absolute;
/*
水平布局:
必记等式
left+margin-left+border-left+padding-left+width+padding-right+border-right+margin-right+right = 父元素内容区的宽度
- 当开启绝对定位以后,就需要添加left 和 right
-- 垂直居中的实现
*/
right: 0;
}
</style>
</head>
<body>
<div class="box1">
<div class="box2"></div>
</div>
</body>
</html>
6、元素的层级
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
div{
font-size: 60px;
}
.box1{
width: 200px;
height: 200px;
background-color: wheat;
position:absolute;
/*
在开启了定位元素,可以通过z-index 属性来指定元素的层级
z-index 需要一个整数作为参数,值越大,层级越高
元素层级越高,越优先显示
当层级一样的时候,显示靠下的元素
祖先元素永远不会盖住后代元素
*/
z-index: 1;
}
.box2{
width: 200px;
height: 200px;
background-color:rgba(255, 0, 0, .5);
position:absolute;
top: 50px;
left: 50px;
z-index: 2;
}
.box3{
width: 200px;
height: 200px;
background-color: red;
position:absolute;
top: 100px;
left: 100px;
z-index: 3;
}
.box4{
width: 100px;
height: 100px;
background-color: rgb(0, 255, 115);
position:absolute;
}
</style>
</head>
<body>
<div class="box1">1</div>
<div class="box2">2</div>
<div class="box3">3
<div class="box4"></div>
</div>
</body>
</html>
7、京东轮播图练习
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
/* 去除默认样式 */
*{
margin: 0;
padding: 0;
}
ul{
margin: 0;
padding: 0;
/* 去除项目符号 */
list-style: none;
margin-left: 20px;
}
.img-list{
width: 400px;
height: 300px;
margin: 100px auto;
/*
ul开启相对定位,是为了可以参照这个定位
*/
position: relative;
}
.img-list li{
position: absolute;
}
.img-list li:nth-child(4){
z-index: 1;
}
.pointer{
position: absolute;
z-index: 9999;
bottom: 20px;
left: 40px;
}
.pointer a{
/* 设置元素向左浮动 */
float: left;
width: 10px;
height: 10px;
margin-left: 4px;
border-radius: 50%;
background-color: rgba(255, 255, 255, .6);
background-clip: content-box;
border: 2px solid transparent;
}
.pointer a.active,
.pointer a:hover{
background-color: #fff;
border: 2px solid rgba(255, 255, 255, .3);
}
</style>
</head>
<body>
<ul class="img-list">
<li class="li1">
<a href="javascript:;">
<img width="400px" height="300px" src="./05/1.jpg">
</a>
</li>
<li>
<a href="javascript:;">
<img width="400px" height="300px" src="./05/2.jpg">
</a>
</li>
<li>
<a href="javascript:;">
<img width="400px" height="300px" src="./05/3.jpg">
</a>
</li>
<li>
<a href="javascript:;">
<img width="400px" height="300px" src="./05/4.jpg">
</a>
</li>
<li>
<a href="javascript:;">
<img width="400px" height="300px" src="./05/5.jpg">
</a>
</li>
<li>
<a href="javascript:;">
<img width="400px" height="300px" src="./05/6.jpg">
</a>
</li>
<li>
<a href="javascript:;">
<img width="400px" height="300px" src="./05/7.jpg">
</a>
</li>
<li>
<a href="javascript:;">
<img width="400px" height="300px" src="./05/8.jpg">
</a>
</li>
<div class="pointer">
<a class="active" href="javascript:;"></a>
<a href="javascript:;"></a>
<a href="javascript:;"></a>
<a href="javascript:;"></a>
<a href="javascript:;"></a>
<a href="javascript:;"></a>
<a href="javascript:;"></a>
<a href="javascript:;"></a>
</div>
</ul>
</body>
</html>
总结
下一篇:字体和背景。