自学前端第七天~

本文详细介绍了CSS中的四种定位方式:相对定位、绝对定位、固定定位和粘性定位。相对定位允许元素相对于其原始位置偏移;绝对定位使元素相对于最近的已定位祖先元素或浏览器窗口定位;固定定位将元素固定在浏览器窗口的特定位置,即使滚动也不会移动;粘性定位则实现了类似吸顶效果,当内容滚动到特定位置时,元素会固定在视口顶部。此外,还讲解了如何创建三角形图标及导航栏的吸顶效果。
摘要由CSDN通过智能技术生成

每天学一点新知识,今天学了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>

 

鼠标放上去会出现倒三角

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值