首页 > 其他分享 >【CSS定位属性】用CSS定位属性精确控制你的网页布局!

【CSS定位属性】用CSS定位属性精确控制你的网页布局!

时间:2024-03-30 14:47:15浏览次数:19  
标签:定位 元素 100px height width background CSS 属性

CSS定位属性是用于控制网页中元素位置的一种方式,它能够让元素在页面上精准地落在我们想要的位置。

在CSS中,定位(Positioning)是控制元素在页面上如何定位和显示的一种机制。它主要包括四种属性:静态定位(static)、相对定位(relative)、绝对定位(absolute)、固定定位(fixed)。

每种定位方式都有其独特的特点和使用场景,下面将分别介绍这几种定位属性。

一、Static(静态定位)

静态定位是元素的默认定位方式,元素按照正常的文档流进行排列。在静态定位状态下,不能配合top、bottom、left、right来改变元素的位置。

  • 可以用于取消元素之前的定位设置。

代码示例:

<!DOCTYPE html>
<html>
<head>
<style>
.static {
  background-color: lightblue;
  padding: 100px;
}
</style>
</head>
<body>


<div>这是一个静态定位的元素。</div>


</body>
</html>

二、Fixed(固定定位)

固定定位使元素相对于浏览器窗口进行定位,即使页面滚动,元素也会保持在固定的位置。

  • 固定定位的元素会脱离正常的文档流。

示例代码:

<!DOCTYPE html>
<html>
<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;
        }
        body{
            /* 给整个页面设置高度,出滚动条以便观察 */
            height: 5000px;
        }
        div{
            width: 100px;
            height: 100px;
            background-color: blue;
            /* 固定定位 */
            position: fixed;
            right: 100px;
            bottom: 100px;
        }
</style>
</head>
<body>
    <div></div>
</body>
</html>

运行结果:

移动前

移动后

比如我们经常看到的网页右下角显示的“返回到顶部”,就可以用固定定位来实现。

<!DOCTYPE html>
<html>
<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>
        body {
            position: relative;
        }
        .content {
            /* 页面内容样式 */
        }
        #backToTop {
            position: fixed;
            bottom: 20px;
            right: 20px;
            background-color: #333;
            color: #fff;
            border: none;
            padding: 10px;
            cursor: pointer;
        }
</style>
</head>
<body style="height: 5000px;">
    <div>
        
    </div>
    <button id="backToTop" onclick="scrollToTop()">返回顶部</button>
    <script>
        function scrollToTop() {
            window.scrollTo({top: 0, behavior: 'smooth'});
        }
</script>
</body>
</html>

运行结果:

三、Relative(相对定位)

相对定位是将元素对于它在标准流中的位置进行定位,通过设置边移属性top、bottom、left、right,使指定元素相对于其正常位置进行偏移。如果没有定位偏移量,对元素本身没有任何影响。

  • 不使元素脱离文档流,空间会保留,不影响其他布局。

代码示例:

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .box1{
            width:200px;
            height:100px;
            background:skyblue;
            margin:10px;
        }
        .box2{
            width:200px;
            height:100px;
            background:pink;
            margin:10px;
            position:relative;/*相对定位*/
            left:100px;/*向右偏移100px*/
            top:-50px;/*向上偏移50px*/
        }
        .box3{
            width:200px;
            height:100px;
            background:yellowgreen;
            margin:10px;
        }
</style>
</head>
<body>
    <div>1</div>
    <div>2</div>
    <div>3</div>
</body>
</html>

运行结果:

没使用相对定位之前是这样的:

使用相对定位后:相对于原来的位置向右偏移了100px,向上偏移50px。

虽然它的位置发生了变化,但它在标准文档流中的原位置依然保留。

四、Absolute(绝对定位)

绝对定位使元素相对于最近的非 static 定位祖先元素进行定位。如果没有这样的元素,则相对于初始包含块(initial containing block)。绝对定位的元素会脱离正常的文档流。

如果该元素为内联元素,则会变成块级元素,可直接设置其宽和高的值(让内联具备快特性);

如果该元素为块级元素,使其宽度根据内容决定。(让块具备内联的特性)

<style>
.wrap{
width:500px;
height:400px;
border: 2px solid red;
}
.box1{
width:200px;
height:100px;
background:skyblue;
margin:10px;
}
.box2{
width:200px;
height:100px;
background:pink;
margin:10px;
position:absolute;/*绝对定位*/
left:100px;/*向右偏移100px*/
top:30px;/*向下偏移30px*/
}
.box3{
width:200px;
height:100px;
background:yellowgreen;
margin:10px;


}
</style>
<div>
       <div>1</div>
       <div>2</div>
       <div>3</div>
       </div>  

将第二个设置为绝对定位后,它脱离了文档流可以定位到页面的任何地方,在标准文档流中的原有位置会空出来,所以第三个会排到第一个下面。

第二个相对于它的父元素向右偏移100,向下偏移30。

五、z-index(层级顺序的改变)

层叠顺序决定了元素之间的堆叠顺序。z-index 属性用于设置元素的层叠顺序。具有较高 z-index 值的元素会覆盖具有较低 z-index 值的元素。

注意:

  • 默认值是0
  • 数值越大层越靠上
  • 不带单位
  • 没有最大值和最小值
  • 可以给负数

代码示例:

<!DOCTYPE html>
<html>
<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:nth-of-type(1){
            width: 300px;
            height: 300px;
            background-color: skyblue;
            position: absolute;
        }
        div:nth-of-type(2){
            width: 200px;
            height: 200px;
            background-color: pink;
            position: absolute;
        }
        div:nth-of-type(3){
            width: 100px;
            height: 100px;
            background-color: yellowgreen;
            position: absolute;
            z-index: -1;
        }
</style>
</head>
<body>
    
    <div></div>
    <div></div>
    <div></div>


</body>
</html>

运行结果:

可以看到,最后一个div依然存在,但是看不见了,原因就是我们改变了z-index属性值。

以上就是CSS定位属性的介绍了,通过这些定位属性,可以灵活地控制网页中元素的位置和堆叠顺序。

在实际应用中,CSS定位属性的使用需要考虑到整体布局和用户体验。合理运用这些定位技巧,可以让你的网页不仅美观,而且易于使用和维护。记住,好的设计总是细节和功能的完美结合。

标签:定位,元素,100px,height,width,background,CSS,属性
From: https://www.cnblogs.com/ydyxcode/p/18105454

相关文章

  • yii2服务定位器
    yii2服务定位器服务定位器是注册和访问组件的对象注册组件useyii\di\ServiceLocator;useyii\caching\FileCache;$locator=newServiceLocator;//通过一个可用于创建该组件的类名,注册"cache"(缓存)组件。$locator->set('cache','yii\caching\ApcCache');//通过......
  • 一文带你搞懂RTK定位
    一文带你搞懂RTK定位附赠自动驾驶学习资料和量产经验:链接说到定位,相信大家一定不会觉得陌生。如今我们所处的信息时代,人人都有手机。每天,我们都会用到与地图和导航有关的APP。这些APP,就是基于定位技术的。说到定位技术呢,大家又肯定会想到GPS、北斗这些名词。是的,这些都属于全......
  • CSS3 实现16:9大屏居中显示
    大屏项目中,一般需要在不同分辨率上显示居中显示大屏内容,且不出现滚动条。实际展示大屏的硬件设备比例不一,为了兼容,并且不出现UI被拉伸的情况,发现可以使用CSS3的transfrom-scale属性,并配合CSS变量实现。其中transfrom-scale用在大屏绘制最外层盒子上,盒子内的样式按照UI给出的16:9......
  • HTML元素语义化补充之css函数(三)
    文章目录CSS中的函数css函数–varcss函数–calccss函数–blurcss函数–gradientlinear-gradient的使用CSS中的函数◼在前面我们有使用过很多个CSS函数:比如rgb/rgba/translate/rotate/scale等;CSS函数通常可以帮助我们更加灵活的来编写样式的值;◼下面有几个......
  • HTML5 和 CSS3 提高
    一、HTML5的新特性HTML5的新增特性主要是针对于以前的不足,增加了一些新的标签、新的表单和新的表单属性等。这些新特性都有兼容性问题,基本是IE9+以上版本的浏览器才支持,如果不考虑兼容性问题,可以大量使用这些新特性。声明:1.新特性增加了很多,但是我们专注于开发......
  • 还记得PostCSS吗,看这一篇文章就够了!!!
    背景由于项目中的使用,又想深入了解,想着写一篇博客,以此监督自我学习~那么首先,让我们带着几个问题来了解一下,PostCSSPostCSS是什么PostCSS有什么用如何使用PostCSS一、是什么官方:用JavaScript代码来处理CSS那么我们根据官方的这一段话,就可以得知一些相关信息......
  • Drools业务规则管理系统25_规则属性
    前面我们已经知道了规则体的构成如下: rule"ruleName"attributeswhenLHSthenRHSend 本章节就是针对规则体的attributes属性部分进行讲解。Drools中提供的属性如下表(部分属性):  一、enabled属性enabled属性对应的取值为true......
  • 几行代码实现人脸定位
    几行代码实现人脸定位importface_recognitionfromPILimportImageimage=face_recognition.load_image_file("IMG_20220519_210830.jpg")face_locations=face_recognition.face_locations(image)forface_locationinface_locations:#打印每张脸的位置信息......
  • css一行显示文本
    1.例如p元素,里面的文字不换行显示,超出部分不隐藏p{width:100px;word-break:keep-all;white-space:nowrap;}2.例如p元素,里面的文字不换行,超出部分用省略号代替p{width:100px;word-break:keep-all;white-space:nowrap;overflow:hidden;text-o......
  • CSS盒子模型
     注:css盒子模型跟ps的基本操作以及圆角切割1.盒子模型1.1网页布局的本质网页布局的核心本质:就是利用CSS摆盒子。网页布局过程:1、先准备好相关的网页元素,网页元素基本都是盒子Box。2、利用CSS设置好盒子样式,然后摆放到相应位置。3、往盒子里面装内容1.2盒子......