CSS学习笔记05

news2025/1/24 11:38:59

CSS笔记05

定位

position

  • CSS 属性position - 用于指定一个元素在文档中的定位方式。toprightbottomleft 属性则决定了该元素的最终位置。position 有以下常用的属性值:
    • position: static; - 默认值。指定元素使用正常的布局行为,即元素在标准文档流中当前的布局位置。此时 top, right, bottom, leftz-index 属性无效。
    • position: relative; - 相对定位,元素先放置在默认的static位置,再在不改变页面布局的前提下调整元素位置。相对定位的元素不会被移出标准文档流,且元素原先在标准文档流中所占的空间会被保留。
    • position: absolute; - 绝对定位,通过指定元素相对于最近的非static定位祖先元素的偏移,来确定元素位置,如果元素没有非static定位的祖先元素,绝对定位元素会相对于初始块容器的位置进行偏移。(初始块容器是一个有着和浏览器视口一样的尺寸的矩形,它包含根元素<html>。)元素绝对定位后会重新生成一个块级框,而不论原来它在正常文档流中生成何种类型的框。绝对定位的元素会被移出标准文档流,且元素原先在标准文档流中所占的空间不会被保留。
    • position: fixed; - 固定定位,通过指定元素相对于浏览器视口(viewport)本身的位置来指定元素位置。元素的位置在屏幕滚动时不会改变。 元素固定定位后也会重新生成一个块级框,而不论原来它在正常文档流中生成何种类型的框。固定定位的元素也会被移出标准文档流,且元素原先在标准文档流中所占的空间不会被保留。
  • 补充 - 视口(viewport):在电脑图形学里面,视口代表了一个可看见的多边形区域(通常来说是矩形)。在浏览器范畴里,它代表的是浏览器中网站可见内容的部分。视口外的内容在被滚动进来前都是不可见的。
  • 下面我们就来详细演示一下这几种定位方式:

静态定位(默认定位) - static

  • position: static; - 默认值。指定元素使用正常的布局行为,即元素在标准文档流中当前的布局位置。此时 top, right, bottom, leftz-index 属性无效。

  • 首先我们设计一个页面,它由一个父级div和三个子级div组成,我们不手动设置position属性(即此时的position属性为其默认值position: static;):

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>默认位置</title>

    <style>
        body {
            padding: 20px;
        }
        div {
            margin: 10px;
            padding: 5px;
            font-size: 12px;
            line-height: 25px;
        }
        #father {
            border: 2px solid black;
        }
        #first {
            background-color: yellow;
            border: 2px dashed orange;
        }
        #second {
            background-color: deepskyblue;
            border: 2px dashed blue;
        }
        #third {
            background-color: lawngreen;
            border: 2px dashed green;
        }
    </style>

</head>
<body>

<div id="father">
    <div id="first">第一个盒子</div>
    <div id="second">第二个盒子</div>
    <div id="third">第三个盒子</div>
</div>

</body>
</html>
  • 我们查看默认情况下的网页效果:

在这里插入图片描述

相对定位 - relative

  • position: relative; - 相对定位,元素先放置在默认的static位置,再在不改变页面布局的前提下调整元素位置。相对定位的元素不会脱离标准文档流,且元素原先在标准文档流中所占的空间会被保留。因此,left: 20px; 会向元素的左外边距边界与其包含块左边界之间添加 20 像素的偏移量,其显示效果便是元素相比于默认位置向右移了 20 像素(在左侧留下了 20 像素的空白)。

  • 我们使用position: relative;将上面默认定位网页中的第一个和第三个div设置为相对定位,并使用toprightbottomleft 属性来改变它们的位置:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>相对定位</title>

    <style>
        body {
            padding: 20px;
        }
        div {
            margin: 10px;
            padding: 5px;
            font-size: 12px;
            line-height: 25px;
        }
        #father {
            border: 2px solid black;
        }
        #first {
            background-color: yellow;
            border: 2px dashed orange;
            position: relative; /* 设置定位方式为相对定位 */
            left: 20px;
            top: -20px;
        }
        #second {
            background-color: deepskyblue;
            border: 2px dashed blue;
        }
        #third {
            background-color: lawngreen;
            border: 2px dashed green;
            position: relative; /* 设置定位方式为相对定位 */
            right: 20px;
            bottom: -20px;
        }
    </style>

</head>
<body>

<div id="father">
    <div id="first">第一个盒子</div>
    <div id="second">第二个盒子</div>
    <div id="third">第三个盒子</div>
</div>

</body>
</html>
  • 查看使用相对定位改变元素位置后的网页效果:

在这里插入图片描述

  • 练习:
    • 使用div和超链接a布局页面
    • 每个超链接宽度和高度都为100px,背景颜色为粉色,当鼠标指针移上去时变为蓝色
    • 使用相对定位改变各个超链接的位置

在这里插入图片描述

  • 代码如下:
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>

    <style>
        #box {
            width: 300px;
            height: 300px;
            border: 2px solid red;
            margin: 0 auto;
            padding: 10px;
        }

        a {
            width: 100px;
            height: 100px;
            display: block;
            background-color: pink;
            line-height: 100px;
            font-size: 15px;
            color: white;
            text-align: center;
            text-decoration: none;
        }

        a:hover {
            background-color: blue;
        }

        #second, #fourth {
            position: relative;
            left: 200px;
            top: -100px;
        }

        #fifth {
            position: relative;
            left: 100px;
            top: -300px;
        }
    </style>

</head>
<body>

<div id="box">
    <a id="first" href="#">链接1</a>
    <a id="second" href="#">链接2</a>
    <a id="third" href="#">链接3</a>
    <a id="fourth" href="#">链接4</a>
    <a id="fifth" href="#">链接5</a>
</div>

</body>
</html>
  • 查看网页效果:

在这里插入图片描述

绝对定位 - absolute

  • position: absolute; - 绝对定位,通过指定元素相对于最近的非static定位祖先元素的偏移,来确定元素位置,如果元素没有非static定位的祖先元素,绝对定位元素会相对于初始块容器的位置进行偏移。(初始块容器是一个有着和浏览器视口一样的尺寸的矩形,它包含根元素<html>。)元素绝对定位后会重新生成一个块级框,而不论原来它在正常文档流中生成何种类型的框。绝对定位的元素会被移出标准文档流,且元素原先在标准文档流中所占的空间不会被保留。
  • 首先我们来测试一下在没有设置非static定位的祖先元素时,使用绝对定位改变元素第二个子div的位置:
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>绝对定位</title>

    <style>
        body {
            padding: 20px;
        }
        div {
            margin: 10px;
            padding: 5px;
            font-size: 12px;
            line-height: 25px;
        }
        #father {
            border: 2px solid black;
        }
        #first {
            background-color: yellow;
            border: 2px dashed orange;
        }
        #second {
            background-color: deepskyblue;
            border: 2px dashed blue;
            position: absolute;
            left: 10px;
            top: 20px;
        }
        #third {
            background-color: lawngreen;
            border: 2px dashed green;
        }
    </style>

</head>
<body>

<div id="father">
    <div id="first">第一个盒子</div>
    <div id="second">第二个盒子</div>
    <div id="third">第三个盒子</div>
</div>

</body>
</html>
  • 查看使用相对定位改变元素位置后的网页效果:

在这里插入图片描述

  • 分析:

在这里插入图片描述

  • 接着我们再来测试一下在设置了非static定位的祖先元素后,使用绝对定位改变元素第二个子div的位置:
  • 将第二个子div的父级元素father设置为相对定位 -relative(通常我们都习惯将使用绝对定位的元素的父级元素设置为相对定位 - “ 子绝父相 ” ):
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>绝对定位</title>

    <style>
        body {
            padding: 20px;
        }
        div {
            margin: 10px;
            padding: 5px;
            font-size: 12px;
            line-height: 25px;
        }
        /* 设置父级元素为非static定位 */
        #father {
            border: 2px solid black;
            position: relative;
        }
        #first {
            background-color: yellow;
            border: 2px dashed orange;
        }
        #second {
            background-color: deepskyblue;
            border: 2px dashed blue;
            position: absolute;
            left: 10px;
            top: 20px;
        }
        #third {
            background-color: lawngreen;
            border: 2px dashed green;
        }
    </style>

</head>
<body>

<div id="father">
    <div id="first">第一个盒子</div>
    <div id="second">第二个盒子</div>
    <div id="third">第三个盒子</div>
</div>

</body>
</html>
  • 查看使用绝对定位改变元素位置后的网页效果:

在这里插入图片描述

  • 分析:

在这里插入图片描述

固定定位 - fixed

  • position: fixed; - 固定定位,通过指定元素相对于浏览器视口(viewport)本身的位置来指定元素位置。元素的位置在屏幕滚动时不会改变。 元素固定定位后也会重新生成一个块级框,而不论原来它在正常文档流中生成何种类型的框。固定定位的元素也会被移出标准文档流,且元素原先在标准文档流中所占的空间不会被保留。

  • 下面我们重新写一个例子:在网页中定义两个div,第一个div使用绝对定位移动到初始块容器的右下角,第二个div使用固定定位移动到浏览器视口的右下角:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>固定定位</title>

    <style>
        body {
            height: 1000px;
        }
        /* 绝对定位,相对于初始包含块(和浏览器视口大小相等的一个矩形) */
        div:nth-of-type(1) {
            width: 200px;
            height: 200px;
            background-color: red;
            position: absolute;
            right: 0;
            bottom: 0;
        }
        /* 固定定位,相对于浏览器视口本身 */
        div:nth-of-type(2) {
            width: 100px;
            height: 100px;
            background-color: blue;
            position: fixed;
            right: 0;
            bottom: 0;
        }
    </style>

</head>
<body>

<div>绝对定位div</div>
<div>固定定位div</div>

</body>
</html>
  • 查看网页效果:

在这里插入图片描述

  • 可以看到此时两个div都移动到了右下角。那么它们的区别在哪里呢?
  • 下面我们滑动浏览器侧边的滚动条:

在这里插入图片描述

  • 我们可以发现使用绝对定位的div的位置会随着屏幕滚动而变化;而使用固定定位的div的位置则不会随着屏幕滚动而变化,始终在当前浏览器视口的右下角。

z-index 与 不透明度

  • 首先我们来理解一下什么是图层:

在这里插入图片描述

  • CSS 属性z-index指定一个元素的堆叠顺序。拥有更高堆叠顺序的元素总是会处于堆叠顺序较低的元素的上层。
  • 演示:
  • 首先我们写一个 HTML 页面:

index.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
	<link rel="stylesheet" href="css/style.css">
</head>
<body>

<div class="content">
    <ul>
        <li><img src="images/bg.png" alt="bg.png"></li>
        <li class="tipText">快来领养猫咪吧</li>
        <li class="tipBg"></li>
        <li>XX宠物救助中心</li>
    </ul>
</div>

</body>
</html>
  • 它的页面效果是这样的:

在这里插入图片描述

  • 我们给它添加一些样式:

style.css

#content {
    width: 460px;
    margin: 0;
    padding: 0;
    overflow-block: hidden;
    font-size: 12px;
    line-height: 25px;
    border: 1px solid black;
}

ul, li {
    margin: 0;
    padding: 0;
    list-style: none;
}

/* 设置父级元素相对定位(子绝父相) */
#content {
    position: relative;
}

/* 绝对定位 */
.tipText, .tipBg {
    width: 460px;
    height: 25px;
    position: absolute;
    top: 285px;
}

.tipText {
    color: white;
}

.tipBg {
    background-color: black;
}
  • 此时的页面效果如下:

在这里插入图片描述

  • 我们发现我们的提示背景tipBg覆盖住了我们的提示文字tipText,导致我们看不到我们的提示文字。
  • 我们现在给提示文字tipText设置堆叠顺序,让它的堆叠顺序更高:

style.css

#content {
    width: 460px;
    margin: 0;
    padding: 0;
    overflow-block: hidden;
    font-size: 12px;
    line-height: 25px;
    border: 1px solid black;
}

ul, li {
    margin: 0;
    padding: 0;
    list-style: none;
}

#content {
    position: relative;
}

.tipText, .tipBg {
    width: 460px;
    height: 25px;
    position: absolute;
    top: 285px;
}

/* z-index - 设置元素的堆叠顺序 */
.tipText {
    color: white;
    z-index: 99;
}

.tipBg {
    background-color: black;
}
  • 此时的页面效果如下:

在这里插入图片描述

  • 补充:为了让页面更美观,我们还可以使用opacity属性设置元素的不透明度:
#content {
    width: 460px;
    margin: 0;
    padding: 0;
    overflow-block: hidden;
    font-size: 12px;
    line-height: 25px;
    border: 1px solid black;
}

ul, li {
    margin: 0;
    padding: 0;
    list-style: none;
}

#content {
    position: relative;
}

.tipText, .tipBg {
    width: 460px;
    height: 25px;
    position: absolute;
    top: 285px;
}

.tipText {
    color: white;
    z-index: 99;
}

/* opacity - 设置元素的不透明度(0.0 ~ 1.0) */
.tipBg {
    background-color: black;
    opacity: 0.5;
    /* filter: alpha(opacity=50); - IE8以及更早版本支持使用filter设置元素的不透明度 */
}
  • 此时的页面效果如下:

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/965683.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

神经网络--感知机

感知机 单层感知机原理 单层感知机:解决二分类问题&#xff0c;激活函数一般使用sign函数,基于误分类点到超平面的距离总和来构造损失函数,由损失函数推导出模型中损失函数对参数 w w w和 b b b的梯度&#xff0c;利用梯度下降法从而进行参数更新。让1代表A类&#xff0c;0代…

es5的实例__proto__(原型链) prototype(原型对象) {constructor:构造函数}

现在看这张图开始变得云里雾里&#xff0c;所以简单回顾一下 prototype 的基本内容&#xff0c;能够基本读懂这张图的脉络。 先介绍一个基本概念&#xff1a; function Person() {}Person.prototype.name KK;let person1 new Person();在上面的例子中&#xff0c; Person …

Nor Flash

核心信息&#xff1a; 工作频率数据吞吐量 bps bit/s&#xff08;传输数据速率&#xff09; Hz&#xff08;时钟频率&#xff09; T/s 56MB/s&#xff08;max&#xff09;448Mb/s&#xff08;数据吞吐量、4路&#xff09;448MHz 112MHz&#xff08;max读、时钟频率&#…

Spring @Configuration 注解解析原理

前言 ​ Configuration 注解是 Spring 3.0 版本引入的新特性&#xff08;目前版本 6.0.11&#xff09;&#xff0c;它用于将一个类标记为配置类&#xff0c;通过配置类可以定义和组装 Spring Bean。 一般来说注解都会有相应的解析器&#xff0c;Configuration 注解靠 C…

Pycharm中出现ImportError:DLL load failed:找不到指定模块的解决方法

不论搭建什么工程&#xff0c;运行什么文件&#xff0c;只要在Pycharm中出现ImportError: DLL load failed: 找不到指定的模块这样的问题&#xff0c;以下方法都适用&#xff01;&#xff01;&#xff01; 一、问题描述 我在使用pycharm连接webots&#xff0c;用python控制机…

Redis功能实战篇之附近商户

在互联网的app当中&#xff0c;特别是像美团&#xff0c;饿了么等app。经常会看到附件美食或者商家&#xff0c; 当我们点击美食之后&#xff0c;会出现一系列的商家&#xff0c;商家中可以按照多种排序方式&#xff0c;我们此时关注的是距离&#xff0c;这个地方就需要使用到我…

JavaScript -【第一周】

文章来源于网上收集和自己原创&#xff0c;若侵害到您的权利&#xff0c;请您及时联系并删除~~~ JavaScript 介绍 变量、常量、数据类型、运算符等基础概念 能够实现数据类型的转换&#xff0c;结合四则运算体会如何编程。 体会现实世界中的事物与计算机的关系理解什么是数据并…

mybatis源码学习-1-调试环境

写在前面,这里会有很多借鉴的内容,有以下三个原因 本博客只是作为本人学习记录并用以分享,并不是专业的技术型博客笔者是位刚刚开始尝试阅读源码的人,对源码的阅读流程乃至整体架构并不熟悉,观看他人博客可以帮助我快速入门如果只是笔者自己观看,难免会有很多弄不懂乃至理解错误…

【科研论文配图绘制】task7密度图绘制

【科研论文配图绘制】task7密度图绘制 task7 了解密度图的定义&#xff0c;清楚密度图是常用使用常见&#xff0c;掌握密度图绘制。 1.什么是密度图 密度图&#xff08;Density Plot&#xff09;是一种用于可视化数据分布的图表类型。它通过在数据中创建平滑的概率密度曲线…

java反编译工具jd-gui使用

文章目录 一、JD-GUI介绍二、下载三、安装四、使用教程五、免责声明摘抄 一、JD-GUI介绍 JD-GUI是一个独立的图形实用程序&#xff0c;显示“.class”文件的Java源代码。 使用JD-GUI浏览重构的源代码&#xff0c;以便即时访问方法和字段。 二、下载 MAC安装包&#xff1a;ht…

Gorm简单了解

GORM 指南 | GORM - The fantastic ORM library for Golang, aims to be developer friendly. 04_GORM查询操作_哔哩哔哩_bilibili 前置&#xff1a; db调用操作语句中间加debug&#xff08;&#xff09;可以显示对应的sql语句 1.Gorm模型定义&#xff08;理解重点&#xff…

在R中安装TensorFlow、TensorFlow_Probability、numpy(R与Python系列第二篇)

目录 前言&#xff1a; 1-安装tensorflow库 Step1: 下载R包tensorflow Step2&#xff1a;安装TensorFlow库 Step3&#xff1a;导入R中 2-安装tensorflow_probability库 Step1&#xff1a;下载R包&#xff1a;tfprobability Step2&#xff1a;安装TensorFlow Probability …

链表OJ练习(2)

一、分割链表 题目介绍&#xff1a; 思路&#xff1a;创建两个链表&#xff0c;ghead尾插大于x的节点&#xff0c;lhead尾插小于x的节点。先遍历链表。最后将ghead尾插到lhead后面&#xff0c;将大小链表链接。 我们需要在创建两个链表指针&#xff0c;指向两个链表的头节点&…

【Mysql系列】(一)MySQL语句执行流程

首发博客地址 首发博客地址 系列文章地址 参考文章 MySQL 逻辑架构 连接器 连接命令一般是这么写的 mysql -h$ip -P$port -u$user -p 那么 什么是连接器&#xff1f; MySQL 连接器&#xff08;MySQL Connector&#xff09;是用于连接和与 MySQL 数据库进行交互的驱动程序。它提…

高级IO

五种IO模型 1、阻塞等待&#xff1a;在内核将数据准备好之前&#xff0c;系统调用会一直等待。所有的套接字&#xff0c;默认都是阻塞方式。 2、非阻塞等待&#xff1a;如果内核没有将数据准备好&#xff0c;系统调用仍然会返回&#xff0c;并且会返回EWUOLDBLOCK或者EAGAIN错…

笔试题目回忆

&#xff08;1&#xff09;给出n,k&#xff0c;n表示数组个数&#xff0c;k表示要剔除的个数&#xff0c;接下来n个数为数组元素&#xff0c;求剔除k个数之后&#xff0c;其他所有数互为倍数&#xff0c;每个数最多剔除一次。 未检测代码&#xff0c;超时。 #include <ios…

第 3 章 栈和队列(单链队列)

1. 背景说明 队列(queue)是一种先进先出(first in first out,缩为 FIFO)的线性表。它只允许在表的一端进行插入&#xff0c;而在另一端删除元素。 2. 示例代码 1&#xff09;status.h /* DataStructure 预定义常量和类型头文件 */#ifndef STATUS_H #define STATUS_H/* 函数结果…

线上问诊:数仓开发(二)

系列文章目录 线上问诊&#xff1a;业务数据采集 线上问诊&#xff1a;数仓数据同步 线上问诊&#xff1a;数仓开发(一) 线上问诊&#xff1a;数仓开发(二) 文章目录 系列文章目录前言一、DWS1.最近1日汇总表1.交易域医院患者性别年龄段粒度问诊最近1日汇总表2.交易域医院患者…

身份识别与鉴权技术调研方案

对称加密算法 对称加密方式又称为私钥加密方式&#xff0c;该方式的加密和解密过程使用同一个密钥&#xff0c;因此该密钥又称为共享密钥。如图2.2所示&#xff0c;在对称加密方式中&#xff0c;发送方使用对称加密算法和共享密钥处理原始数据&#xff0c;得到一个加密后的密文…

vulnhub渗透测试靶场练习2

靶场介绍 靶场名&#xff1a;easy_cloudantivirus 靶场地址&#xff1a;https://www.vulnhub.com/entry/boredhackerblog-cloud-av,453 环境搭建 依旧使用VM VirtualBox搭建靶场&#xff0c;攻击机使用的是VMware中的kali&#xff0c;需要将VMware虚拟机kali和virtualbox靶机…