本篇文章给大家带来了css定位布局的相关知识,下面我们就来看一下什么是相对定位、绝对定位以及固定定位不同的元素性质与用途等知识,希望对大家有帮助。
相对定位:盒子可以根据自己原来的位置进行位置调整(通过位置描述词实现)。
位置描述词:
left: 向右移动; right 向左移动;top 向下移动;bottom 向上移动
(当里面值为负数的时候,往相反方向移动)
举个例子:
原来:
<!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>相对定位</title> <style> * { margin: 0; padding: 0; } p { width: 500px; height: 500px; border: 1px solid #000; margin: 50px auto; } p { width: 100px; height: 100px; background-color: lightblue; position: relative; top: 50px; left: 50px; } </style></head><body> <p> <p></p> </p></body></html>
将 p 设置成相对定位:
p { width: 100px; height: 100px; background-color: lightblue; position: relative; top: 50px; left: 50px;}
性质
用途
举个例子:
76c82f278ac045591c9159d381de2c579fd01892b579bba0c343404bcccd70fb93f0f5c25f18dab9d176bd4f6de5d30e a80eb7cbb6fff8b0ff70bae37074b813 db71bb30709ba44a555bb4f052ca6598 8f6d5a544bbc0d98e0f297ef053f784d b2386ffb911b14667cb8f0f91ea547a7相对定位6e916e0f7d1e588d4f442bf645aedb2f c9ccee2e6ea535a969eb3f532ad9fe89 * { margin: 0; padding: 0; } nav { width: 780px; height: 50px; margin: 40px auto; } nav ul { list-style: none; } nav ul li { float: left; width: 156px; height: 50px; line-height: 50px; text-align: center; } nav ul li a { display: block; width: 156px; height: 50px; background-color: lightcyan; color: #000; text-decoration: none; } nav ul li a:hover { border-top: 3px solid red; } 531ac245ce3e4fe3d50054a55f2659279c3bca370b5104690d9ef395f2c5f8d16c04bd5ca3fcae76e30b72ad730ca86d c787b9a589a3ece771e842a6176cf8e9 ff6d136ddc5fdfeffaf53ff6ee95f185 25edfb22a4f469ecb59f1190150159c6 f1b3ba8846c179e65eb68da95b01a812导航一5db79b134e9f6b82c0b36e0489ee08ed bed06894275b65c1ab86501b08a632eb 25edfb22a4f469ecb59f1190150159c6 f1b3ba8846c179e65eb68da95b01a812导航二5db79b134e9f6b82c0b36e0489ee08ed bed06894275b65c1ab86501b08a632eb 25edfb22a4f469ecb59f1190150159c6 f1b3ba8846c179e65eb68da95b01a812导航三5db79b134e9f6b82c0b36e0489ee08ed bed06894275b65c1ab86501b08a632eb 25edfb22a4f469ecb59f1190150159c6 f1b3ba8846c179e65eb68da95b01a812导航四5db79b134e9f6b82c0b36e0489ee08ed bed06894275b65c1ab86501b08a632eb 25edfb22a4f469ecb59f1190150159c6 f1b3ba8846c179e65eb68da95b01a812导航五5db79b134e9f6b82c0b36e0489ee08ed bed06894275b65c1ab86501b08a632eb 929d1f5ca49e04fdcb27f9465b944689 44f9630a3d507ae7532760da37622b0f36cc49f0c466276486e50c850b7e495673a6ac4ed44ffec12cee46588e518a5e
这个时候效果是这样:
会发现鼠标悬浮在上面的时候,导航那一块区域都会下沉
我们给它设置了相对定位并微调之后:
nav ul li a:hover { border-top: 3px solid red; position: relative; top: -3px;}
这样就可以解决刚刚的问题了
绝对定位:盒子以坐标进行位置描述,拥有自己绝对位置。
绝对定位的参考盒子:
绝对定位的盒子会以自己的祖先元素中,离自己最近的拥有定位属性的盒子,当做基准点。
这个盒子通常是相对定位的,所以也被称作 “子绝父相”。
位置描述词:
left:到左边的距离;right:到右边的距离;top:到上边的距离;bottom:到下边的距离
举个例子:
76c82f278ac045591c9159d381de2c579fd01892b579bba0c343404bcccd70fb93f0f5c25f18dab9d176bd4f6de5d30e a80eb7cbb6fff8b0ff70bae37074b813 db71bb30709ba44a555bb4f052ca6598 8f6d5a544bbc0d98e0f297ef053f784d b2386ffb911b14667cb8f0f91ea547a7绝对定位6e916e0f7d1e588d4f442bf645aedb2f c9ccee2e6ea535a969eb3f532ad9fe89 * { margin: 0; padding: 0; } .box { position: absolute; width: 500px; height: 300px; left: 200px; top: 100px; background-color: antiquewhite; } 531ac245ce3e4fe3d50054a55f2659279c3bca370b5104690d9ef395f2c5f8d16c04bd5ca3fcae76e30b72ad730ca86d 9890cd3db8af2c13be66110fccb4c149 94b3e26ee717c64999d7867364b1b4a336cc49f0c466276486e50c850b7e495673a6ac4ed44ffec12cee46588e518a5e
绝对定位的盒子垂直居中:
.box { position: absolute; top: 50%; margin-top: -自己高度一半;}
绝对定位的盒子水平居中:
.box { position: absolute; left: 50%; margin-left: -自己宽度一半;}
设置绝对定位元素的压叠顺序.
是一个没有单位的正整数,数值大的能够压住数值小的(即数值大的显示在上层)
举个例子:
76c82f278ac045591c9159d381de2c579fd01892b579bba0c343404bcccd70fb93f0f5c25f18dab9d176bd4f6de5d30e a80eb7cbb6fff8b0ff70bae37074b813 db71bb30709ba44a555bb4f052ca6598 8f6d5a544bbc0d98e0f297ef053f784d b2386ffb911b14667cb8f0f91ea547a7绝对定位6e916e0f7d1e588d4f442bf645aedb2f c9ccee2e6ea535a969eb3f532ad9fe89 * { margin: 0; padding: 0; } .box1 { width: 300px; height: 300px; position: absolute; left: 100px; top: 100px; background-color: antiquewhite; } .box2 { width: 300px; height: 300px; position: absolute; left: 200px; top: 200px; background-color: lightblue; } 531ac245ce3e4fe3d50054a55f2659279c3bca370b5104690d9ef395f2c5f8d16c04bd5ca3fcae76e30b72ad730ca86d 270a51b956a23b98a0f876f9d602125c94b3e26ee717c64999d7867364b1b4a3 fb95984df8f79ab56a41c584a417d18a94b3e26ee717c64999d7867364b1b4a336cc49f0c466276486e50c850b7e495673a6ac4ed44ffec12cee46588e518a5e
此时效果如下:
<br/>
这个时候我们想让box1显示在上层,就设置一个z-index 属性。
.box1 { width: 300px; height: 300px; position: absolute; left: 100px; top: 100px; background-color: antiquewhite; z-index: 100;}.box2 { width: 300px; height: 300px; position: absolute; left: 200px; top: 200px; background-color: lightblue; z-index: 1;}
看看效果:
绝对定位用来“压盖”,“遮罩”的效果
可以结合 CSS 精灵使用
可以结合 JS 实现一些动画
固定定位:不管页面如何滚动,它永远以页面为参考点,固定在那里。
位置描述词:
left:到左边的距离;right:到右边的距离;top:到上边的距离;bottom:到下边的距离
.box { position: fixed; top: 100px; left: 100px;}
可以用来实现一些元素要一直浮现在当前窗口前,比如浏览一个页面时的返回顶部按钮,会一直出现在当前页面的某个位置
举个例子:
<!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>固定定位</title> <style> * { margin: 0; padding: 0; } .box { position: fixed; bottom: 20px; right: 20px; width: 40px; height: 40px; text-align: center; line-height: 40px; border-radius: 50%; background-color: rgba(78, 209, 226, 0.5); cursor: pointer; font-size: 24px; } </style></head><body> <a class="box">^</a> <p> <img src="https://dummyimage.com/600x400/00bcd4/fff" alt=""> </p> <p> <img src="https://dummyimage.com/600x400/00bcd4/fff" alt=""> </p> <p> <img src="https://dummyimage.com/600x400/00bcd4/fff" alt=""> </p></body></html>
效果如下:
当页面到下方时,右下角返回顶部的按钮位置不变。
大家感兴趣的话,可以继续访问:css视频教程。
以上是深入浅析了解CSS中定位布局的细节的详细内容。更多信息请关注PHP中文网其他相关文章!