当前位置: 首页 > article >正文

CSS `transform` 属性详解:打造视觉效果与动画的利器

CSS `transform` 属性详解:打造视觉效果与动画的利器

    • 引言
    • 一、`transform` 属性简介
    • 二、平移(Translation)
    • 三、旋转(Rotation)
    • 四、缩放(Scale)
    • 五、倾斜(Skew)
    • 六、组合变换(Combining Transforms)
    • 七、3D变换(3D Transforms)
    • 八、动画和过渡(Animations and Transitions)
    • 九、布局和对齐(Layout and Alignment)
    • 十、总结

引言

在现代网页设计中,视觉效果和动画是提升用户体验的重要手段。CSS 的 transform 属性是实现这些效果的有力工具。本文将深入解析 transform 属性的各个方面,帮助你掌握其使用方法,创建出丰富多彩的视觉效果和动画。

一、transform 属性简介

transform 是 CSS 中一个非常强大的属性,用于对元素进行二维或三维的变换。它可以帮助你实现平移、旋转、缩放、倾斜等效果,从而创建出各种视觉效果和动画。

二、平移(Translation)

用途:将元素在页面上水平或垂直移动。

示例

.element {transform: translateX(20px); /* 水平向右移动20px */transform: translateY(30px); /* 垂直向下移动30px */transform: translate(20px, 30px); /* 水平向右20px,垂直向下30px */
}

效果:元素在页面上移动,但不会改变其在文档流中的位置。

三、旋转(Rotation)

用途:围绕一个点旋转元素。

示例

.element {transform: rotate(45deg); /* 顺时针旋转45度 */transform: rotate(-90deg); /* 逆时针旋转90度 */
}

效果:元素围绕其自身中心点旋转。

四、缩放(Scale)

用途:改变元素的大小。

示例

.element {transform: scaleX(2); /* 水平方向放大两倍 */transform: scaleY(0.5); /* 垂直方向缩小到原来的一半 */transform: scale(1.5); /* 水平和垂直方向都放大1.5倍 */
}

效果:元素的尺寸会按指定比例放大或缩小。

五、倾斜(Skew)

用途:使元素的边角倾斜。

示例

.element {transform: skewX(30deg); /* 水平方向倾斜30度 */transform: skewY(45deg); /* 垂直方向倾斜45度 */transform: skew(30deg, 45deg); /* 水平方向倾斜30度,垂直方向倾斜45度 */
}

效果:元素的边角会向指定方向倾斜。

六、组合变换(Combining Transforms)

用途:同时应用多种变换。

示例

.element {transform: translate(50px, 50px) rotate(45deg) scale(1.2);
}

效果:元素先平移,然后旋转,最后放大。

七、3D变换(3D Transforms)

用途:在三维空间中变换元素,创建更复杂的视觉效果。

示例

.element {transform: rotateX(30deg); /* 绕X轴旋转30度 */transform: rotateY(45deg); /* 绕Y轴旋转45度 */transform: rotateZ(60deg); /* 绕Z轴旋转60度 */transform: translateZ(50px); /* 沿Z轴向前移动50px */transform: scaleZ(1.5); /* 沿Z轴放大1.5倍 */
}

效果:元素在三维空间中移动、旋转和缩放。

八、动画和过渡(Animations and Transitions)

用途:通过变换属性创建平滑的动画效果。

示例

.element {transition: transform 0.5s ease-in-out; /* 指定过渡效果 */
}.element:hover {transform: scale(1.1); /* 鼠标悬停时放大 */
}

效果:当鼠标悬停在元素上时,元素会平滑地放大。

九、布局和对齐(Layout and Alignment)

用途:在不改变HTML结构的情况下,调整元素的位置和对齐方式。

示例

.container {display: flex;justify-content: center;align-items: center;
}.element {transform: translate(-50%, -50%); /* 将元素居中对齐 */
}

效果:通过变换属性,可以更灵活地控制元素的布局和对齐。

十、总结

transform 属性是 CSS 中非常灵活和强大的工具,适用于各种视觉效果和动画。通过平移、旋转、缩放、倾斜和3D变换,你可以创建出丰富多彩的视觉效果。结合 transitionanimation,你还可以实现平滑的过渡和复杂的动画序列。

相关文章:

CSS `transform` 属性详解:打造视觉效果与动画的利器

CSS transform 属性详解:打造视觉效果与动画的利器 引言一、transform 属性简介二、平移(Translation)三、旋转(Rotation)四、缩放(Scale)五、倾斜(Skew)六、组合变换&am…...

【落羽的落羽 数据结构篇】顺序结构的二叉树——堆

文章目录 一、堆1. 概念与分类2. 结构与性质3. 入堆4. 出堆 二、堆排序三、堆排序的应用——TOP-K问题 一、堆 1. 概念与分类 上一期我们提到,二叉树的实现既可以用顺序结构,也可以用链式结构。本篇我们来学习顺序结构的二叉树,起个新名字—…...

基于STM32的智能农业大棚环境控制系统

1. 引言 传统农业大棚环境调控依赖人工经验,存在控制精度低、能耗高等问题。本文设计了一款基于STM32的智能农业大棚环境控制系统,通过多参数环境监测、作物生长模型与精准执行控制,实现大棚环境的智能优化,提高作物产量与品质。…...

Git常见命令--助力开发

git常见命令: 创建初始化仓库: git 将文件提交到暂存区 git add 文件名 将文件提交到工作区 git commit -m "注释(例如这是发行的版本1)" 文件名 查看状态 如果暂存区没有文件被提交显示: $ git status On…...

一:将windows上的Python项目部署到Linux上,并使用公网IP访问

windows中python的版本:python3.13.1,项目使用的是虚拟环境解释器 linux系统:仅有python3.6.7 服务器:阿里云服务器有公网IP,访问端口XXXX 在linux上安装python3.13.1 linux中如果是超级管理员root,执行所…...

1_2 流浪地球(python)

1.题目 分值:100 题目描述 流浪地球计划在赤道上均匀部署了N个转向发动机,按位置顺序编号为0~N-1。 初始状态下所有的发动机都是未启动状态。 发动机启动的方式分为“手动启动”和“关联启动”两种方式如果在时刻1一个发动机被启动,下一个时…...

【数据标准】数据标准化是数据治理的基础

导读:数据标准化是数据治理的基石,它通过统一数据格式、编码、命名与语义等,全方位提升数据质量,确保准确性、完整性与一致性,从源头上杜绝错误与冲突。这不仅打破部门及系统间的数据壁垒,极大促进数据共享…...

计算机视觉:经典数据格式(VOC、YOLO、COCO)解析与转换(附代码)

第一章:计算机视觉中图像的基础认知 第二章:计算机视觉:卷积神经网络(CNN)基本概念(一) 第三章:计算机视觉:卷积神经网络(CNN)基本概念(二) 第四章:搭建一个经典的LeNet5神经网络(附代码) 第五章&#xff1…...

七星棋牌顶级运营产品全开源修复版源码教程:6端支持,200+子游戏玩法,完整搭建指南(含代码解析)

棋牌游戏一直是移动端游戏市场中极具竞争力和受欢迎的品类,而七星棋牌源码修复版无疑是当前行业内不可多得的高质量棋牌项目之一。该项目支持 6大省区版本(湖南、湖北、山西、江苏、贵州),拥有 200多种子游戏玩法,同时…...

编程考古-忘掉它,Delphi 8 for the Microsoft .NET Framework

忘掉它吧,作一篇记录! 【圣何塞,加利福尼亚 – 2003年11月3日】在今日的Borland开发者大会上,Borland正式推出了Delphi 8 for Microsoft .NET Framework。这款新版本旨在为Delphi开发者提供一个无缝迁移路径,将现有的…...

宠物智能可穿戴产品调研报告

一、引言 随着人们生活水平的提高以及情感陪伴需求的增长,宠物在家庭中的地位愈发重要,宠物经济蓬勃发展。宠物智能可穿戴产品作为宠物市场与科技融合的新兴领域,正逐渐走进大众视野,为宠物饲养与管理带来新的变革。本调研旨在深…...

[通俗易懂C++]:指针和const

之前的文章有说过,使用指针我们可以改变指针指向的内容(通过给指针赋一个新的地址)或者改变被保存地址的值(通过给解引用指针赋一个新值): int main() {int x { 5 }; // 创建一个整数变量 x,初始值为 5int* ptr { &x }; // 创建一个指针 ptr,指向 …...

大一高数(上)速成:导数和微分

目录 1.分段函数的可导性: 2.隐函数求导: 3.参数方程求导: 4.对数求导法: 5.函数的微分: 1.分段函数的可导性: 2.隐函数求导: 3.参数方程求导: 4.对数求导法: 5.函数的微分:...

使用 DeepSeek 和 Google Gemini 算命

目录 DeepSeek 调用Gemini 调用基础 PromptFAQ1. Gemini 返回失败2. DeepSeek 超时 DeepSeek 调用 由于 DeepSeek API 是兼容 openai 的,所以直接使用 openai 的 sdk 即可。 // Please install OpenAI SDK first: npm install openaiimport OpenAI from openai; i…...

京东cfe滑块 分析

声明: 本文章中所有内容仅供学习交流使用,不用于其他任何目的,抓包内容、敏感网址、数据接口等均已做脱敏处理,严禁用于商业用途和非法用途,否则由此产生的一切后果均与作者无关! 逆向分析 headers {"accept&qu…...

list结构刨析与模拟实现

目录 1.引言 2.C模拟实现 2.1模拟实现结点 2.2模拟实现list前序 1)构造函数 2)push_back函数 2.3模拟实现迭代器 1)iterator 构造函数和析构函数: *操作符重载函数: 前置/后置/--: /!操作符重载…...

react 踩坑记 too many re-renders.

报错信息: too many re-renders. React limits the number of randers to prevent an infinite loop. 需求 tabs只有特定标签页才展示某些按钮 button要用 传递函数引用方式 ()>{} *还有要注意子组件内loading触发 导致的重复渲染...

BGP分解实验·19——BGP选路原则之起源

当用不同的方式为BGP注入路由时,起源代码将标识路由的来源。 (在BGP表中,Network为“i”,重分布是“?”) 实验拓扑如下: R2上将来自IGP的路由10.3.3.3/32用network指令注入BGP;在R4上将来自I…...

二叉树中每个节点能到达的最远距离

一、题目描述 输入一个只包含0和1的字符串表示二叉树,输出每个节点能到达的最远距离,通过父节点的路径也要考虑。 比如输入"111110000010000", 输出[3,2,4,3,3,4]。 1A / \ 1B 1C / \ / \ 1D 1E 0 0 / \ /…...

单机上使用docker搭建minio集群

单机上使用docker搭建minio集群 1.集群安装1.1前提条件1.2步骤指南1.2.1安装 Docker 和 Docker Compose(如果尚未安装)1.2.2编写docker-compose文件1.2.3启动1.2.4访问 2.使用2.1 mc客户端安装2.2创建一个连接2.3简单使用下 这里在ubuntu上单机安装一个m…...

结构体简介

前言 这篇文章呢就给大家简单讲解一下什么是结构体,也让大家对结构体有一个较为清晰的了解,从而帮助同学们更好的掌握结构体。 结构体类型的声明 结构的声明 在声明结构体的类型是,先给大家拓展两个重要的关键字 typedef 和 struct. 拓展…...

家用路由器的WAN口和LAN口有什么区别

今时今日,移动终端盛行的时代,WIFI可以说是家家户户都有使用到的网络接入方式。那么路由器当然也就是家家户户都不可或缺的设备了。而路由器上的两个实现网络连接的基础接口 ——WAN 口和 LAN 口,到底有什么区别?它们的功能和作用…...

实操解决Navicat连接postgresql时出现‘datlastsysoid does not exist‘报错的问题

1 column “datlastsysoid“ does not exist2 Line1:SELECT DISTINCT datalastsysoid FROM pg_database问题分析 Postgres 15 从pg_database表中删除了 datlastsysoid 字段引发此错误。 决绝方案 解决方法1:升级navicat 解决方法2:降级pgsql 解决方…...

3分钟idea接入deepseek

DeepSeek简介 DeepSeek 是杭州深度求索人工智能基础技术研究有限公司开发的一系列大语言模型,背后是知名量化资管巨头幻方量化3。它专注于开发先进的大语言模型和相关技术,拥有多个版本的模型,如 DeepSeek-LLM、DeepSeek-V2、DeepSeek-V3 等&…...

树莓派理想二极管电路分析

如果 Vin Vout,比如说 5.0V,PNP 晶体管以当前的镜像配置偏置。晶体管 U14 的 Vb 将为 5-0.6 4.4V,镜像配置意味着 Vg 也将为 4.4V. Vgs 为4.4-5.0 -0.6V。mosfet 将处于关闭状态(几乎打开)。如果 Vout 略低于 Vin&a…...

关于在mac中配置Java系统环境变量

引言 在 macOS 上开发 Java 或 Flutter 应用时,正确配置环境变量是至关重要的。环境变量不仅能让系统找到开发工具的位置,还能简化命令行操作。本文将手把手教你从零开始安装 Java SDK,并详细配置环境变量,涵盖常见问题解决和优化…...

Unity贴图与模型相关知识

一、贴图 1.贴图的类型与形状 贴图类型 贴图形状 2.在Unity中可使用一张普通贴图来生成对应的法线贴图(但并不规范) 复制一张该贴图将复制后的贴图类型改为Normal Map 3.贴图的sRGB与Alpha sRGB:勾选此选项代表此贴图存储于Gamma空间中…...

Linux--进程(进程虚拟地址空间、页表、进程控制、实现简易shell)

一、进程虚拟地址空间 这里以kernel 2.6.32,32位平台为例。 1.空间布局 在 32 位系统中,虚拟地址空间大小为 4GB。其中: 内核空间:占据高地址的 1GB ,用于操作系统内核运行,包含内核代码、内核数据等&am…...

中间件专栏之redis篇——redis基本原理、概念及其相关命令介绍

一、redis是什么 redis是remote dictionary service的简称,中文翻译为远程字典服务; redis是一种数据库,若按照类型来归类,则其可以被归入三个类型数据库,分别为:内存数据库、KV数据库、数据结构数据库&a…...

python使用httpx_sse调用sse流式接口对响应格式为application/json的错误信息的处理

目录 问题描述方案 问题描述 调用sse流式接口使用httpx_sse的方式 import httpxfrom httpx_sse import connect_sse# 省略无关代码try:with httpx.Client() as client:with connect_sse(client, "GET", url, paramsparam) as event_source:clear_textbox(response_t…...