Day08:CSS 高级

目标:掌握定位的作用及特点;掌握 CSS 高级技巧


一、定位

作用:灵活的改变盒子在网页中的位置

实现:

1.定位模式:position

2.边偏移:设置盒子的位置

  • left
  • right
  • top
  • bottom

水平方向偏移:left、right,垂直方向偏移:top、bottom

1、相对定位

position: relative

特点:

  • 不脱标,占用自己原来位置
  • 显示模式特点保持不变(如:块级显示模式使用相对定位后还是块级显示模式)
  • 设置边偏移则相对自己原来位置移动
div {position: relative;top: 100px;left: 200px;
}	

因为相对定位不脱标,即使自己发生了偏移,还占用自己原来的位置,后面的元素没办法顶上去,会留下一片空白,所以实际开发中很少单独使用相对定位,经常配合着绝对定位一起使用。

2、绝对定位

position: absolute

使用场景:子级绝对定位,父级相对定位(子绝父相

特点:

  • 脱标,不占位
  • 显示模式具备行内块特点(即使是行内元素,使用了绝对定位后,设置宽高生效)
  • 设置边偏移则相对最近的,已经定位的祖先元素改变位置
  • 如果祖先元素都未定位,则相对浏览器可视区改变位置
.father {position: relative;
}.father span {position: absolute;top: 0;right: 0;
}

练习:使用绝对定位,实现图片在浏览器居中定位。

在这里插入图片描述

实现步骤:

  1. 设置元素绝对定位,没有最近的祖先元素设置定位属性,则该元素的绝对定位相对于浏览器可视窗口改变位置;
  2. 水平、垂直边偏移为 50%,此时图片的左上角正好在浏览器的中心位置,需要向左、向上偏移,使图片中心移动到浏览器可视窗口的中心;
  3. 子级向左、向上移动自身尺寸的一半。
  • 量出图片尺寸,设置 margin-left: -宽度的一半,margin-top: -高度的一半。
  • 使用 transform 属性,transform 是元素位置偏移,transform: translate(-50%, -50%)。

代码如下:

<head><style>img {/* 子级设置为绝对定位,没有父级,相对浏览器可视区域改变位置 */position: absolute;left: 50%;top: 50%;/* 设置 margin-left: -宽度的一半,margin-top: -高度的一半 *//* margin-left: -265px;margin-top: -127px; *//* 方便:50% 就是自己宽高的一半 */transform: translate(-50%, -50%);}</style>
</head><body><img src="./images/login.webp" alt="">
</body>
3、固定定位

position: fixed

场景:元素的位置在网页滚动时不会改变

特点:

  • 脱标,不占位
  • 显示模式具备行内块特点
  • 设置边偏移相对浏览器窗口改变位置
  • 元素的位置相对浏览器窗口,不会改变
div {position: fixed;top: 0;right: 0;background-color: blue;width: 500px;height: 200px
}

二、堆叠层级 z-index

在这里插入图片描述

默认效果:按照标签书写顺序,后来者居上

作用:设置定位元素的层级顺序,改变定位元素的显示顺序

属性名:z-index

属性值:整数数字(默认值为0,取值越大,层级越高)

<head><style>div {position: absolute;width: 200px;height: 200px;}.box1 {background-color: pink;/* 取值是整数,默认是0,取值越大显示顺序越靠上 */z-index: 3;}.box2 {background-color: skyblue;left: 100px;top: 100px;z-index: 1;}</style>
</head><body><div class="box1">box1</div><div class="box2">box2</div>
</body>

在这里插入图片描述


三、CSS 高级

1、精灵图

CSS 精灵,也叫 CSS Sprites,是一种网页图片应用处理方式。把网页中一些背景图片整合到一张图片文件中,再background-position 精确的定位出背景图片的位置。
在这里插入图片描述

优点:减少服务器被请求次数,减轻服务器的压力,提高页面加载速度。

实现步骤:

  1. 创建盒子,盒子尺寸小图尺寸相同
  2. 设置盒子背景图为精灵图
  3. 添加 background-position 属性,改变背景图位置
    3.1 使用 PxCook 测量小图片左上角坐标
    3.2 取负数坐标为 background-position 属性值(因为3.1量出来图片左上角的坐标,要向左、向上移动精灵图,才能使要显示的部分移动到盒子的位置)
<head><style>div {width: 112px;height: 110px;background-color: pink;background-image: url(./images/abcd.jpg);background-position: -256px -276px;}</style>
</head><body><div></div>
</body>

在这里插入图片描述

2、字体图标

在这里插入图片描述
字体图标:展示的是图标,本质是字体

作用:在网页中添加简单的、颜色单一的小图标

优点

  • 灵活性:灵活地修改样式,例如:尺寸、颜色等
  • 轻量级:体积小、渲染快、降低服务器请求次数
  • 兼容性:几乎兼容所有主流浏览器
  • 使用方便:先下载再使用
(1)下载字体图标

国内免费的字体图标网站:iconfont 阿里巴巴矢量图标库

流程:登录 → 寻找图标 → 加入购物车 → 购物车,添加至项目,确定 → 下载至本地
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

(2)使用字体图标

下载解压的文件如下:
在这里插入图片描述

  • demo_index.html:查看字体图标,双击打开后,点击 font class 选项,复制需要使用的字体图标名称
  • iconfont.css 使用时,需要通过 link 引入到 html 中的 css 文件
  • ttf、woff、woff2 真正的字体文件

流程:

  1. 将下载好的字体图标文件全部拖到项目中;
  2. 在 html 中引入字体样式表 iconfont.css ;
  3. 标签使用字体图标类名;
    • iconfont:字体图标基本样式(字体名,字体大小等等)
    • icon-xxx:图标对应的类名,在 demo_index.html 中复制字体图标名称
  4. 如果要修改字体图标样式,至少要使用类选择器进行修改,不能使用标签选择器,因为在 iconfont.css 中已经使用了 .iconfont {} 类选择器,至少要使用类选择器修改字体图标样式才能覆盖生效。
<head><style>.iconfont {font-size: 200px;color: red;}/* 通过字体图标的名称作为类选择器修改样式 */.icon-icon-test1 {color: green;}/* 自定义一个类选择器,修改图标样式 */.myClass {font-size: 100px;color: palevioletred;}</style>
</head><body><span class="iconfont icon-icon-test2"></span><span class="iconfont icon-icon-test1"></span><span class="iconfont myClass icon-icon-test3"></span>
</body>

在这里插入图片描述

(3)上传矢量图

作用:项目特有的图标上传到 iconfont 图标库,生成字体,再按照(2)步骤下载使用。(需要上传的图标需要是 svg 的格式)。

上传步骤:上传 → 上传图标 → 选择 svg 矢量图,打开 → 提交 → 系统审核

在这里插入图片描述


四、CSS 修饰属性

1、垂直对齐方式
(1)基线

在行内和行内块元素中,一行的元素默认是基线对齐,图片是行内块元素,默认也是基线对齐。

(1)当一行只有图片一个元素时,图片底部为什么会有留白。
(2)当一行有图片和文字时,图片和文字为什么没有居中对齐。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

通过这个图,可以很清楚的了解到为什么会出现(1)(2)问题,因为浏览器在处理行内、行内块元素时,会使用基线对齐的方式,图片的底部和文字的基线对齐,这就是为什么会出现(2)问题。图片的底部为什么会留白,因为有的字母下面会超过基线,比如图片中的p字母,所以浏览器会给基线下面留出一些空白间距,图片是行内块元素,所以浏览器也会给图片下面流出一些空白间距。

(2)对齐方式

属性名:vertical-align

属性值效果
baseline基线对齐(默认)
top顶部对齐
middel居中对齐
bottom底部对齐
<head><style>div {border: 1px solid #000;}img {/* 居中对齐 */vertical-align: middle;/* 顶对齐:最高内容的顶部 *//* vertical-align: top; *//* 底对齐:最高内容的底部 *//* vertical-align: bottom; *//* 因为浏览器把行内块、行内标签当做文字处理,默认按基线对齐 *//* 效果:图片img的底下有空白,转块级不按基线对齐,空白就消失了 *//* display: inline-block; */}</style>
</head><body><div><img src="./images/1.webp" alt=""><span>我是谁?我在哪?</span></div>
</body>

在这里插入图片描述

居中对齐属性要添加到比较大的元素身上。
只要不是默认的基线对齐方式,图片的底部就没有留白,bottom 对齐方式,图片底部也没有留白。
如果一行只有图片这一个元素,可以给图片转换显示模式:display: block; 也可以去除底部留白。

2、过渡

作用:可以为一个元素在不同状态之间切换的时候添加过渡效果

属性名:transition(复合属性)

属性值:过渡的属性 花费时间 (s)

提示:

  • 过渡的属性可以是具体的 CSS 属性
  • 也可以为 all(两个状态属性值不同的所有属性,都产生过渡效果)
  • transition 设置给元素本身
<head><style>img {width: 200px;height: 150px;transition: all 1s;}img:hover {width: 500px;height: 400px;}</style>
</head><body><img src="./images/huawei.jpg" alt="">
</body>

在这里插入图片描述

3、透明度 opacity

作用:设置整个元素的透明度(包含背景和内容)

属性名:opacity

属性值:0 – 1

  • 0:完全透明(元素不可见)
  • 1:不透明
  • 0-1之间小数:半透明
4、光标类型cursor

作用:鼠标悬停在元素上时指针显示样式

属性名:cursor

属性值效果
default默认值,通常是箭头
pointer小手效果,提示用户可以点击
text工字型,提示用户可以选择文字
move十字光标,提示用户可以移动

只是改变了鼠标的样式,具体效果还需要配合 js 来实现。



在这里插入图片描述

乾坤未定,你我皆是黑马


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

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

相关文章

mac下载安装好软件后提示已损坏

mac下载安装好软件后提示已损坏 解决方法&#xff1a; 首先确保系统安全设置已经改为任何来源。 打开任何来源后&#xff0c;到应用程序目录中尝试运行软件&#xff0c;如果仍提示损坏&#xff0c;请在应用图标上&#xff0c;鼠标右键&#xff0c;在弹出菜单中点打开。 如果…

埃及媒体分发投放-新闻媒体通稿发布

埃及商业新闻 大舍传媒近日宣布将在埃及商业新闻领域展开新的媒体分发投放。作为埃及最具影响力的商业新闻平台之一&#xff0c;埃及商业新闻将为大舍传媒提供广阔的市场和受众群体。这一合作意味着大舍传媒将有机会通过埃及商业新闻的平台向埃及的商业精英和投资者传递最新的…

SpringBoot项目启动时提示程序包不存在和找不到符号

一、前言 最近接手同事开发的一个Springboot工作项目&#xff0c;从svn上整体拉取下来后&#xff0c;构建完成后&#xff0c;启动的时候遇到了程序包找不到的情况&#xff0c;记录一下处理过程&#xff1b; 二、项目问题 1、报错信息&#xff1a;启动后报 java: 程序包org.sp…

升级 JDK17 一个不可拒绝的理由!

插&#xff1a; AI时代&#xff0c;程序员或多或少要了解些人工智能&#xff0c;前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家(前言 – 人工智能教程 ) 坚持不懈&#xff0c;越努力越幸运&#xff0c;大家…

Spring AOP基于动态代理的实现的 AOP

目录 代理什么是代理代理模式 静态代理动态代理JDK动态代理CGLIB动态代理Spring AOP使用的是哪种代理&#xff1f; 代理 什么是代理 生活中的代理 房产中介 &#xff1a; 房屋进行租赁时&#xff0c;卖方会把房子授权给中介&#xff0c;由中介代理带客户看房&#xff0c;商谈…

行为型设计模式之模板模式

文章目录 概述原理结构图实现 小结 概述 模板方法模式(template method pattern)原始定义是&#xff1a;在操作中定义算法的框架&#xff0c;将一些步骤推迟到子类中。模板方法让子类在不改变算法结构的情况下重新定义算法的某些步骤。 模板方法中的算法可以理解为广义上的业…

Function Calling学习

Function Calling第一篇 Agent&#xff1a;AI 主动提要求Function Calling&#xff1a;AI 要求执行某个函数场景举例&#xff1a;明天上班是否要带伞&#xff1f;AI反过来问你&#xff0c;明天天气怎么样&#xff1f; Function Calling 的基本流程 Function Calling 完整的官…

北斗高精度定位终端的工作原理和精度范围

北斗高精度定位终端的工作原理主要基于北斗卫星导航系统&#xff0c;通过卫星信号的接收、处理和计算&#xff0c;实现了对目标位置的精确测量。以下是关于北斗高精度定位终端工作原理的引文&#xff1a; ​ 北斗高精度定位终端作为一款新型的高精定位设备&#xff0c;其核心…

pg_lakehouse 与 datafusion

原理分析 pg_lakehouse 是 ParadeDB 推出的一个开源插件&#xff0c;支持对多种数据湖里的数据做分析计算。它的出现&#xff0c;使得 Postgres 能够像访问本地数据一样轻松访问 S3 等对象存储&#xff0c;轻松访问 Delta Lake 上的表格&#xff0c;具备数据湖分析能力。 pg_…

微信小程序实现容器图片流式布局功能,配合小程序原生框架使用。

小程序实现容器图片流式布局功能&#xff0c;因为目前论坛上也有很多博主出过类似的文章&#xff0c;这里我就以一个小白角度去讲一下如何实现的吧。给作者一点点鼓励&#xff0c;先点个赞赞吧&#x1f44d;&#xff0c;蟹蟹&#xff01;&#xff01; 目标 实现下方效果图 技术…

sonar3 使用 api/measures/componet 获取代码当,Java实现

最近团队在做一个技术架构相关的优化&#xff0c;当前的目标是想要通过代码量&#xff0c;系统架构入手。先统计到部门的代码量&#xff0c;如何进行代码行数的统计呢&#xff0c;因为我们采用的是Java技术栈&#xff0c;我就Java技术栈进行说明。 1、如何统计代码行数 要统计…

ZYNQ AXI4 FDMA内存读写

1 概述 如果用过ZYNQ的都知道,要直接操作PS的DDR 通常是DMA 或者VDMA,然而用过XILINX 的DMA IP 和 VDMA IP,总有一种遗憾,那就是不够灵活,还需要对寄存器配置,真是麻烦。对于我们搞 FPGA 的人来说,最喜欢直接了当,直接用FPGA代码搞定。现在XILINX 的总线接口是AXI4总线…

latex中复制到word里面之后如何转变成word自带的公式

详细步骤如下&#xff1a; 第一步&#xff0c;将latex中的公式复制到word里面&#xff0c;例如&#xff1a;$r_1^d$ 第二步&#xff0c;选中$$里面的部分&#xff0c;也就是去掉$$&#xff0c;选中剩余的部分&#xff0c;例如&#xff1a;r_1^d 第三步&#xff0c;word工具栏里…

【代码随想录】【算法训练营】【第21天】 [530]二叉搜索树的最小绝对差 [501]二叉搜索树的众数 [236]二叉树的最近公共祖先

前言 思路及算法思维&#xff0c;指路 代码随想录。 题目来自 LeetCode。 day 21&#xff0c;天气不错的周二~ 题目详情 [530] 二叉搜索树的最小绝对差 题目描述 530 二叉搜索树的最小绝对差 解题思路 前提&#xff1a;二叉搜索树 思路&#xff1a;根据二叉搜索树的中…

长安链使用Golang编写智能合约教程(二)

本篇说的是长安链2.3.的版本的智能合约&#xff0c;虽然不知道两者有什么区别&#xff0c;但是编译器区分。 教程三会写一些&#xff0c;其他比较常用SDK方法的解释和使用方法 编写前的注意事项&#xff1a; 1、运行一条带有Doker_GoVM的链 2、建议直接用官方的在线IDE去写合…

奥枫软件Java要个16K遇到地狱级难度,醉了。。。

我只能说地狱难度&#xff0c;没绝对把握就别去了。我凭借前辈的经验&#xff0c;和当时天时地利人和&#xff0c;六道题答得很不错&#xff0c;但还是没通过。我有备而来都没过&#xff0c;现场写那些应该都是白忙活了。 一面 1&#xff0c;分割一个整数。如123&#xff0c;结…

抖音本地生活服务商入驻指南分享!

当前&#xff0c;各大平台的团购外卖业务持续火爆&#xff0c;并逐渐成为众多创业赛道中的大热门。其中&#xff0c;本地生活服务更是在短时间内杀出重围&#xff0c;成为创业者们的首选。 根据抖音生活服务近日发布的《2023年度数据报告》&#xff0c;2023年&#xff0c;抖音生…

2024年湖北水平能力测试能搞定吗?

武汉中级职称报名正式高一段落&#xff0c;意味着今年武汉市中级职称报名除开东湖高新区之外&#xff0c;其余地方都已经正式截止了&#xff0c;那么接下来大家都在准备6月中下旬的水平能力测试考试。 水平能力测试分为两种&#xff1a;面试答辩或者笔试机考试卷&#xff0c;面…

vue脚手架与创建vue项目

一、前言 vue脚手架的安装与创建vue项目需要先行安装配置node与npm&#xff0c;详情可以看node、npm的下载、安装、配置_node 下载安装-CSDN博客 二、vue脚手架的使用 1、vue与vue脚手架的版本 Vue脚手架&#xff08;Vue CLI&#xff09;是Vue.js官方提供的一个命令行工具&…

【基础篇-Day8:JAVA字符串的学习】

目录 1、常用API2、String类2.1 String类的特点2.2 String类的常见构造方法2.3 String类的常见面试题&#xff1a;2.3.1 面试题一&#xff1a;2.3.2 面试题二&#xff1a;2.3.3 面试题三&#xff1a;2.3.4 面试题四&#xff1a; 2.4 String类字符串用于比较的方法2.5 String类字…