百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程文章 > 正文

CSS Transform css transform翻转效果

qiyuwang 2024-10-18 10:29 10 浏览 0 评论

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);
}

正如您在上面的示例中看到的,我们使用degturn单位来定义我们的旋转。deg单位从 0 到 360,而turn单位从 0 到 1。

3D 旋转

rotateX您还可以使用、rotateYrotateZ函数进行 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 一样,有一个translateXtranslateY函数可以一次只在一个方向上移动一个元素。

百分比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您可以使用skewXskewY在一个方向上倾斜元素而不影响其他方向一样。

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 变量的帮助下,这个问题是微不足道的。

相关推荐

centos7使用yum安装nginx+php7+mysql5.6

本文主要介绍安装在centos7下如何安装nginx+php+mysql的环境,centos7的版本自带安装源的版本无法实现PHP5.4以上的版本,数据库默认用的是mariadb,文章介绍的安装是如何...

Linux基础入门(VMWare中CentOS7配置yum)

上一章节,介绍了《Linux基础入门(CentOS7下通过命令行配置网络)》,本章将介绍如何配置yum源,方便后续在学习和使用的过程中,对所需工具的安装;...

CentOS 7搭建Nextcloud私有云(centos搭建云盘)

Nextcloud简介:对于私人网盘,其中最出名的就是seafile、owncloud和nextcloud。seafile是国人开发的,有免费和企业版,免费的功能有限;nextcloud是owncl...

分享一个docker镜像源地址,解决docker不能拉取的问题

自己搭建的代理,centos7只需要修改/etc/docker/daemon.json并输入以下内容:{"registry-mirrors":["https://next...

源支付5.18版全套开源源码客户端+云端+监控+协议三网免挂免输入

源支付5.18最新版协议去授权全套三端开源源码_客户端+云端+监控+协议三网免挂免输入(全套版)推荐系统为:CentOS7.6Linux系统环境:Nginx1.20.1+MySQL5.6....

centos7飞速搭建zabbix5.0并添加windows、linux监控

一、环境zabbix所在服务器系统为centos7,监控的服务器为windows2016和centos7。二、安装zabbix官方安装帮助页面...

CentOS上配置 Docker 使用代理服务器

hub.docker最近总被墙,国内大厂搞的docker镜像源代理被封被停,对于一个严重依赖一些海外项目的软件开发人员,简直没法干活了。docker要在CentOS上配置Docker使用代理服...

CentOS 7 (阿里云虚拟机) 安装 Docker

一、安装Docker1.使用root权限登录CentOS。确保yum包更新到最新sudoyumupdate...

Centos离线静默安装 oracle11g,步骤细验证成功

一、环境要求1.1.涉及工具及环境1)CentOS764位系统2)oracle安装包文件a)linux.x64_11gR2_database_1of2.zip...

Linux运维之制作指定软件包的YUM源

#挑战30天在头条写日记#关注我,不迷路,大家好,我是大王。--记录运维中遇到的故障及排查方法...

在CentOS 9 安装Nvidia显卡驱动详细操作步骤

今天给粉丝网友演示CentOS9系统下如何安装nvidia显卡驱动。·将下载好的显卡驱动放到文件夹中,这里以download为例,放入文件夹中开始对系统软件升级,是为了防止在安装显卡驱动时显示报错...

基于Linux系统的本地Yum源搭建与配置(ISO方式、RPM方式)

前言:由于公司业务服务器大部分都在内网环境下运行,内网环境无法直接使用yum安装升级更新软件,所以需要自建Yum源来满足目前日常工作需要。...

最新zabbix一键安装脚本(基于centos8)

一、环境准备注意:操作系统必须是centos8及以上的,因为我配的安装源是centos8的。并且必须连接互联网,脚本是基于yum安装的!!!...

CentOS7中使用yum安装Nginx的方法

1、添加源  默认情况Centos7中无Nginx的源,最近发现Nginx官网提供了Centos的源地址。因此可以如下执行命令添加源(...

Centos8出现Failed to download metadata for repo 'AppStream'解决

大家都知道Centos8于2021年年底停止了服务,大家再在使用yum源安装时候,出现下面错误“错误:Failedtodownloadmetadataforrepo'AppStre...

取消回复欢迎 发表评论: