每天学一点新知识,今天学了css里面关于定位的知识。
之前设置模块要设置很多外边距和内边距,感觉学了定位就简单很多。定位有相对定位、绝对定位、固定定位、粘性定位。可以方便设置模块在页面的位置,方便固定位置。
相对定位:
position: static 默认值,不支持top、left、bottom、right位置 position:relative 相对于自己本来的位置偏移,和top、left、bottom、right位置搭配使用
<style>
div{
width: 200px;
height: 200px;
}
.box1{
background-color: red;
}
.box2{
background-color: yellow;
position: relative;
top: 100px;
left: 100px;
}
.box3{
background-color: blue;
}
</style>
</head>
<body>
<div class="box1"></div>
<div class="box2"></div>
<div class="box3"></div>
</body>
中间黄色模块相对于自己之前的位置,距离上方100px,左边100px。
绝对定位
position:absolute 没有父盒子时或者父盒子没有定位时,相对于浏览器第一屏移动,父盒子有定位时,子盒子相对于父盒子移动。一般建议父盒子设置相对位置relative、不设置方向值,子盒子设置绝对定位。
<style>
*{
margin: 0;
height: 0;
}
.father{
width: 400px;
height: 400px;
background-color: green;
margin: 0 auto;
position: relative;
}
.box{
width: 200px;
height: 200px;
background-color: yellow;
position: absolute;
top: 100px;
left: 100px;
}
</style>
</head>
<body>
<div class="father">
<div class="box"></div>
</div>
</body>
因为黄色盒子外面有父盒子,且父盒子设置了相对定位relative,黄色子盒子设置了绝对定位,距离父盒子上方100px、左边100px。
固定定位
固定定位很好理解,就是固定在页面某个位置不动,虽然相对定位也可以固定位置,但是只相对浏览器的第一屏,随着拉动滚动条,如果设置相对定位对于后面的浏览器窗口就会消失了。所以有一个固定定位的属性。
position:fixed 相遇于浏览器窗口固定
<style>
.box1{
width: 2000px;
height: 1000px;
background-color: green;
}
.box2{
width: 50px;
height: 100px;
position: fixed;
right: 0;
bottom: 100px;
background-color: yellow;
}
</style>
</head>
<body>
<div class="box1">
</div>
<div class="box2"></div>
</body>
黄色盒子设置固定定位,随着滚动条滚动也不会消失。
粘性定位
粘性定位主要用于导航栏,当滚动条运动到一定位置时,如果想让导航栏随着内容屏幕一起移动,就需要这个粘性定位。
positon:sticky 可以做吸顶效果,配合设置top:0px,意思是在离顶部0px的时候开始吸顶。
<style>
*{
margin: 0;
padding: 0;
}
.header{
width: 100%;
height: 100px;
background-color: yellow;
}
.nav{
width: 500px;
height: 50px;
background-color: red;
margin:0 auto;
position: sticky;
top: 0px;
}
.body{
height: 1000px;
background-color: green;
}
</style>
</head>
<body>
<div class="header"></div>
<div class="nav"></div>
<div class="body"></div>
</body>
红色代表导航栏
导航栏距离顶部0px时开始粘住。随着滚动条滚动一直粘在顶部。
还有一个三角形的图标设置有些导航栏会用到~
原理就是利用设置四个方向的边框,将边框宽度设置成想要的三角形高,将其中三个方向边框设置成透明,长度和宽度都设置成0px,其中一个方向就会显示出三角符号。想要什么方向的三角都可以设置。
<style>
.box2{
width: 0;
height: 0;
border: 20px solid transparent;
border-bottom:20px solid red;
}
.box1{
width: 0;
height: 0;
border: 20px solid transparent;
border-top:20px solid red;
}
</style>
</head>
<body>
<div class="box1">
</div>
<div class="box2">
</div>
</body>
一个三角形导航的案例~
<style>
.box{
width: 100px;
height: 30px;
background-color: lightblue;
color: white;
text-indent: 20px;
line-height: 30px;
}
span{
width: 0;
height: 0;
border: 5px solid transparent;
border-top: 5px solid black;
position: relative;
display: inline-block;
top: 2.5px;
}
.box:hover span{
width: 0;
height: 0;
border: 5px solid transparent;
border-bottom: 5px solid black;
position: relative;
top: -2.5px;
}
</style>
</head>
<body>
<div class="box">
导航
<span></span>
</div>
</body>
鼠标放上去会出现倒三角