定位
所谓定位,实际上就是定义元素框相对其正常位置,应该出现在哪儿。
简单说: 定位就是改变元素的页面上的默认的位置
2.定位的分类
1.普通流定位(元素默认的定位方式)
2.浮动定位
3.相对定位
4.绝对定位
5.固定定位
3.定位-普通流定位
文档流定位是页面元素的默认定位方式
页面中的块级元素按照从上到下的排列方式每一个元素时独占一行的
页面中的行内元素按照从左到右的排列方式,当前行装不了(溢出)会自动换行
4.浮动定位
1.浮动定位的概述
如果我将元素设置了浮动定位那么具备以下几个特点:
1.浮动元素脱离了普通的文档流不占据页面空间的其他没有浮动的元素会自动上前部位
2.浮动元素会停靠在父级元素的左边或者右边,或者停靠在其他已经浮动的元素的边缘上
3.浮动元素只会在当前行内浮动
4.浮动元素依然位于父元素内
5.让多个元素在一行内显示
2.语法:float: left(左浮动) right(右浮动) none(默认,无浮动的效果)
以下实现三个盒子的浮动
<head>
<meta charset="utf-8" />
<title>浮动</title>
<style type="text/css">
.box {
width: 300px;
height: 500px;
border: 1px solid red;
}
.noe {
width: 100px;
height: 100px;
background-color: red;
display: inline-block;
float: left;
}
.two {
width: 100px;
height: 100px;
background-color: green;
float: right;
}
.three {
width: 100px;
height: 100px;
background-color: yellow;
float: right;
}
</style>
</head>
<body>
<div class="box">
<div class="noe">
</div>
<div class="two">
</div>
<div class="three">
</div>
</div>
</body>
当使用 clear: both; 清除浮动我们就可以做到以下效果
清除左右浮动
clear: both;
使该盒子不受上一个元素浮动的影响也就是
不占据上一行的位置但是自身可以浮动
3.清除浮动:
如果元素浮动起来之后,除了影响到自己的位置还会影响到后续的元素
在这样的情况下 不想被前面浮动元素影响的话 可以使用清除浮动来解决这个问题。
语法;
clear:
left:清除当前元素前面的元素左浮动带来的影响(只和自己相关,并不和前面的元素相关)
当前元素不会向前占位并且左边不允许有浮动元素。
right:
清除当前元素前面的元素右浮动带来的影响,当前元素不会向前占位并且右不允许有浮动元素。
both:
清除当前元素前面的元素左浮动和右浮动带来的影响,当前元素不会向前占位并且左右不允许有浮动元素。
浮动元素对父元素带来的影响
由于浮动元素脱离了文档流所以导致不占据父元素页面空间
解决问题:
1.直接给父级元素设置高度
弊端:必须要知道父级准确的高度
2.设置父级元素的浮动
弊端:对后续的元素会有影响
3.设置父级元素overflow hidden或auto
弊端:如果子级溢出的话 会一起被隐藏
4.在父元素中追加一个空元素(子元素)并且设置他clear:both