CSS Transform
itomcoil 2025-01-05 18:05 12 浏览
CSS 在您可以修改的内容方面非常强大,并且该transform属性是最通用和最强大的 CSS 属性之一。在本文中,我将介绍使用transform属性修改 CSS 元素的所有方法。
什么是变换属性?
CSS 中的transform属性只是一种您可以在一个属性中旋转、缩放、移动等元素的方式。由于这种灵活性,如果起初使用起来可能会令人困惑,但本文将消除所有这些困惑。
.class {
transform: rotate(90deg) scale(2) translate(100px, 200px);
}
transform通过组合多个变换函数来获得所需的输出,因此为了理解transform您需要了解每个transform函数。
rotate
可能最容易理解的变换函数是rotate. 此函数采用单个参数,即旋转元素的角度。正值将导致顺时针旋转,负值将导致逆时针旋转。
.red {
transform: rotate(10deg);
}
.green {
transform: rotate(-45deg);
}
.blue {
transform: rotate(.25turn);
}
正如您在上面的示例中看到的,我们使用deg和turn单位来定义我们的旋转。deg单位从 0 到 360,而turn单位从 0 到 1。
3D 旋转
rotateX您还可以使用、rotateY和rotateZ函数进行 3D 旋转。该rotateZ功能的工作原理与rotate.
rotateX将在水平轴上rotateY旋转一个元素,并将在垂直轴上旋转一个元素。这些可用于翻转元素。
.red {
transform: rotateX(60deg);
}
.green {
transform: rotateY(60deg);
}
.blue {
transform: rotateX(.2turn) rotateY(.2turn);
}
如您所见,我们在 3D 空间中旋转元素,使其看起来被挤压。这种旋转实际上只在处理 3D 元素时才有用。
scale
scale是另一个很容易理解的函数。它可以采用一个或两个参数来确定元素大小的缩放比例。大于 1 的数字会使元素变大,而小于 1 的数字会缩小元素。
.red {
transform: scale(1.25);
}
.green {
transform: scale(.5);
}
.blue {
transform: scale(1.25, .75);
}
当一个参数被传递给scale它时,它会根据传递的数字缩放 X 和 Y 轴相同的量。当两个值传递给scale第一个数字时,将缩放 X 轴,第二个数字将缩放 Y 轴。
此外,如果您愿意,可以使用scaleXandscaleY函数来缩放 X 或 Y 轴。这些函数采用一个参数并在相应轴上缩放元素。
3D 比例
就像rotate您可以在 3D 中缩放一样。为此,您将使用与 and 类似的函数scaleZ,但用于 Z 轴。这同样只对 3D 元素有用。scaleX``scaleY
translate
可能我最喜欢的转换元素的方法是使用translate函数。这个函数像scale函数一样接受一个或两个参数,并将根据提供的值移动一个元素。
.red {
transform: translate(25px);
}
.green {
transform: translate(-25px, 25px);
}
.blue {
transform: translate(0, -25px);
}
透明的彩色箭头表示形状通常放置的位置,而不透明的箭头表示它们在平移后的位置。
你会注意到,当只有一个值被传递给它时,translate它只会影响 X 轴,因此元素向右移动 25 个像素,因为它是一个正值。
当将两个值传递给translate第一个值时,会在 X 轴上移动元素,而第二个值会影响 Y 轴的位置。这意味着绿色箭头向左移动 25 个像素,向下移动 25 个像素。正 Y 值将元素向下移动似乎令人困惑,因为我们通常认为正 Y 意味着向上,但在 Web 开发中,正 Y 值意味着元素在页面中向下移动。
最后,蓝色箭头向上移动了 25 个像素,因为第一个参数设置为 0,第二个参数设置为负 25 个像素。
就像 scale 一样,有一个translateX和translateY函数可以一次只在一个方向上移动一个元素。
百分比translate
该translate属性处理百分比的方式与几乎所有其他 CSS 属性不同,因为它基于元素的大小而不是其父级的大小。
.red {
transform: translate(100%);
}
正如你所看到的,当我们用百分比平移时,我们将元素向右移动了其自身宽度的 100%。这对于通过将元素移动其自身宽度的 50% 或将元素彼此偏移其大小的百分比来使元素居中非常有用。
3D translate
您现在可能已经猜到了,但translate也可以在 3D 中使用。您可以使用translateZ仅修改 Z 轴的函数或translate3D类似 的函数translate,但接受第三个参数来在 Z 轴上移动元素。同样,这仅对 3D 元素有用。
偏斜
可能所有transform功能中最没用的是skew. 它允许您通过倾斜形状的边缘来拉伸形状。该skew函数接受一两个参数,就像translate.
.red {
transform: skew(25deg);
}
.green {
transform: skew(15deg, 25deg);
}
.blue {
transform: skew(-15deg, -25deg);
}
如您所见,skew 属性在 X 和 Y 方向上拉伸了我们的形状。通过指定一个参数,我们只在 X 方向上倾斜,而如果我们传递两个属性,第一个在 X 方向上倾斜,第二个在 Y 方向上倾斜。
此外,就像translate您可以使用skewX和skewY在一个方向上倾斜元素而不影响其他方向一样。
3D 倾斜
不同的是,所有其他transform属性skew都没有任何 3D 版本。
组合变换
到目前为止,我们已经讨论了单独使用转换,但是如果您想使用多个转换怎么办?这实际上非常简单,因为您可以传递任意数量的函数transform。
.red {
transform: rotate(25deg) scale(.5) translateX(50px);
}
.green {
transform: rotate(-.5turn) translateX(-10%);
}
.blue {
transform: scaleX(1.2) scaleY(.8);
}
组合转换变得困难的唯一时候是当您想要在不同的类中修改它们时。
.base-class {
transform: scale(1.2) translateX(5px);
}
.big {
transform: scale(2) translateX(5px);
}
.move {
transform: scale(1.2) translateX(100px);
}
.big.move {
transform: scale(2) translateX(100px);
}
由于transform是一个属性,您需要在修改的每个类之间复制所有值,transform因为如果您只是transform: scale(2)在.big类中写入,它将覆盖整个transform而不只是scale部分。幸运的是,我们可以巧妙地使用 CSS 变量来解决这个问题。
.base-class {
transform: scale(var(--scale, 1.2)) translateX(var(--translate-x, 5px));
}
.big {
--scale: 2;
}
.move {
--translate-x: 100px;
}
如您所见,我们现在只更改 CSS 变量,而从未修改实际transform属性。
结论
总体而言,CSStransform非常有用,同时也非常易于理解。到目前为止,最难的部分transform是理解如何跨不同类组合多个变换,但在 CSS 变量的帮助下,这个问题是微不足道的。
相关推荐
- Python 上下文管理器魔法手册:with 语句的终极艺术
-
对话实录小白:(抓狂)我写了f=open("data.txt"),结果忘记关闭文件了!专家:(掏出魔法书)用with语句,文件自动关闭,永不泄露!上下文管理器基础三连击1.基...
- 【验证码逆向专栏】某安登录流程详解与验证码逆向分析与识别
-
声明本文章中所有内容仅供学习交流使用,不用于其他任何目的,不提供完整代码,抓包内容、敏感网址、数据接口等均已做脱敏处理,严禁用于商业用途和非法用途,否则由此产生的一切后果均与作者无关!本文章未经许可禁...
- Python常用内置模块介绍——文件与系统操作详解
-
Python提供了多个强大的内置模块用于文件和系统操作,下面我将详细介绍最常用的几个模块及其核心功能。1.os模块-操作系统交互os模块提供了与操作系统交互的接口,包括文件/目录操作、进程管理、环...
- 21-Python-文件操作
-
在Python中,文件操作是非常重要的一部分,它允许我们读取、写入和修改文件。下面将详细讲解Python文件操作的各个方面,并给出相应的示例。1-打开文件在Python中,使用`open()`函数来打...
- Python 开发工程师必会的 5 个文件操作库
-
在Python开发的世界里,文件操作是一项基础且高频的任务。从日常的数据处理到复杂的项目部署,熟练掌握文件操作库能让我们的开发工作事半功倍。本文和大家聊聊我眼中开发必备的5个文件操作库,它们各...
- 你应该知道的 50 个 Python 单行代码
-
使用Python总是可以轻松完成一些特定任务,这让人惊奇。一些比较繁琐的任务可以使用Python在单行代码中完成。下面是我收集的50个Python单行代码实例。1.移位词:猜字母的个...
- Python10个了不起的10个库,用于文件操作、接口测试
-
日常接口测试中需要大量的操作文件,譬如:用户登录信息、数据库信息等等。了解下方10个文件操作库,可以快速提升在工作中的效率。os:提供了与操作系统交互的功能,包括文件和目录操作、进程管理等。示例代码参...
- 手把手教你开发智能备份神器,小白也能30分钟搞定!
-
一、你的电脑是不是也总在“重复备份”?每次备份文件夹时,是不是总觉得“好麻烦”?特别是遇到几十G的文件库,整个备份过程像在坐过山车——明明大部分文件都没改,却还要从头来一遍!今天,我用Python开发...
- 几行代码教你zip打包
-
01准备有时我们不想去手动一个个去操作,然后傻等他打包完,python依赖库zipfile很方便地帮助我们封装了解压压缩,shutil用于文件目录处理,方法类似于linux命令。1、安装pipin...
- Python操作目录
-
获取当前工作目录获取执行命令的位置路径拼接路径拆分文件重命名删除文件复制文件遍历文件夹下的文件判断文件是否存在判断目录是否存在获取当前工作目录importsysprint(sys.path[0]...
- Python 开发工程师必会的 5 个系统命令操作库
-
当我们需要编写自动化脚本、部署工具、监控程序时,熟练操作系统命令几乎是必备技能。今天就来聊聊我在实际项目中高频使用的5个系统命令操作库,这些可都是能让你效率翻倍的"瑞士军刀"。一...
- 文件备份用Python,照着复制粘贴代码就可以了
-
引言在日常开发和运维工作中,数据安全尤为重要,定期备份重要文件是防范数据丢失的有效手段之一。本文将详细介绍如何使用Python实现一个简单的定时备份脚本,该脚本可以按照设定周期自动将指定文件夹或文件复...
- 2025年必学的Python自动化办公的15个实用脚本
-
2025年必学的Python自动化办公的6个实用脚本及其代码示例。这些脚本涵盖了文件备份、邮件通知、网页抓取、报告生成、数据处理和团队协作等多个场景,帮助用户高效完成日常办公任务。1.自动备份文件自...
- 一天学一点,今天学习掌握Python:异常处理与文件操作全攻略
-
这一笔记记录了我学习python的异常和文件的操作,这也是针对Python异常和文件操作教程的进一步优化建议和注意事项:异常处理优化1.避免过度捕获异常o不要为了捕获异常而捕获异常,应根据实际需求...
- 「亲测可用」如何用python脚本批量旋转图片为任意角度?
-
最近在训练图片方向分类器,需要对原始图片进行批量旋转操作,那如何用python脚本实现批量旋转图片为任意角度呢?此处,以将我的头像旋转90度为例进行演示。实现图片批量旋转的python源代码如下:#-...
- 一周热门
- 最近发表
- 标签列表
-
- ps图案在哪里 (33)
- super().__init__ (33)
- python 获取日期 (34)
- 0xa (36)
- super().__init__()详解 (33)
- python安装包在哪里找 (33)
- linux查看python版本信息 (35)
- python怎么改成中文 (35)
- php文件怎么在浏览器运行 (33)
- eval在python中的意思 (33)
- python安装opencv库 (35)
- python div (34)
- sticky css (33)
- python中random.randint()函数 (34)
- python去掉字符串中的指定字符 (33)
- python入门经典100题 (34)
- anaconda安装路径 (34)
- yield和return的区别 (33)
- 1到10的阶乘之和是多少 (35)
- python安装sklearn库 (33)
- dom和bom区别 (33)
- js 替换指定位置的字符 (33)
- python判断元素是否存在 (33)
- sorted key (33)
- shutil.copy() (33)