Vue知识点(5)-- 动画

news2025/4/18 6:06:00

CSS 动画是 Vue3 中实现组件动画效果的高效方式,主要通过 CSS transitionskeyframes 动画

CSS Keyframes(关键帧动画)

用来创建复杂的动画序列,可以精确控制动画的各个阶段。

核心语法:

@keyframes animationName {
	0% { /* 起始状态 */ }
	50% { /* 中间状态 */ }
	100% { /* 结束状态 */ }
}

.cssClass{
	animation: 
	  name            // 动画名称 (对应 @keyframes 名称)(必需)
	  duration        // 动画持续时间(必需)
	  timing-function // 动画速度曲线
	  delay           // 动画延迟时间
	  iteration-count // 动画播放次数
	  direction       // 动画播放方向
	  fill-mode       // 动画前后如何应用样式
	  play-state;     // 动画运行状态
}

每一个参数都可以单独的修改和使用

  1. animation-name (必需)
    指定要应用的 @keyframes 动画名称
@keyframes example {
  from { opacity: 0; }
  to { opacity: 1; }
}

.element {
  animation-name: example;
}
  1. animation-duration (必需)
    定义动画完成一个周期所需时间
.element {
  animation-duration: 2s; /* 可以是秒(s)或毫秒(ms) */
}
  1. animation-timing-function
    定义动画的速度曲线
    描述
    ease默认值,慢快慢
    linear匀速
    ease-in慢开始
    ease-out慢结束
    ease-in-out慢开始和结束
    cubic-bezier(n,n,n,n)自定义贝塞尔曲线
    steps(n)分步动画
.element {
  animation-timing-function: cubic-bezier(0.1, 0.7, 1.0, 0.1);
}
  1. animation-delay
    定义动画开始前的延迟时间
.element {
  animation-delay: 1s; /* 1秒后开始动画 */
}
  1. animation-iteration-count
    定义动画播放次数
    描述
    number具体次数 (如 2, 3.5)
    infinite无限循环
.element {
  animation-iteration-count: infinite;
}
  1. animation-direction
    定义动画播放方向
    描述
    normal默认,正向播放
    reverse反向播放
    alternate先正向后反向交替
    alternate-reverse先反向后正向交替
.element {
  animation-direction: alternate;
}
  1. animation-fill-mode
    定义动画执行前后如何应用样式
    描述
    none默认,不应用任何样式
    forwards保持最后一帧样式
    backwards应用第一帧样式
    both同时应用 forwards 和 backwards
.element {
  animation-fill-mode: forwards;
}
  1. animation-play-state
    控制动画的播放状态
    描述
    running默认,动画运行
    paused动画暂停
.element:hover {
  animation-play-state: paused;
}

案例实践:

//基于CSS class的动画
<template>
	<div :class="{ shake: disabled }">
		<button @click="warnDisabled">Click me</button>
		<span v-if="disabled">This feature is disabled!</span>
	</div>
</template>

<script setup>
import { ref } from 'vue'
const disabled = ref(false)
const warnDisabled = () => {
    disabled.value = true
    setTimeout(() => {
        disabled.value = false
    }, 1500)
}
</script>

<style scoped>
.shake {
  animation: shake 0.82s cubic-bezier(0.36, 0.07, 0.19, 0.97) both;
  transform: translate3d(0, 0, 0);
}
@keyframes shake {
  10%,
  90% {
    transform: translate3d(-1px, 0, 0);
  }
  20%,
  80% {
    transform: translate3d(2px, 0, 0);
  }
  30%,
  50%,
  70% {
    transform: translate3d(-4px, 0, 0);
  }
  40%,
  60% {
    transform: translate3d(4px, 0, 0);
  }
}
</style>

CSS Transitions(过渡动画)

用于在元素从一种状态转变为另一种状态时添加平滑的过渡效果。

核心语法:

.cssClass{
	transition: 
	  [property]       // 要过渡的CSS属性
	  [duration]       // 过渡持续时间(必需)
	  [timing-function] // 过渡速度曲线
	  [delay];         // 过渡延迟时间
}
  1. transition-property(可选)
    指定应用过渡效果的 CSS 属性名称

常见可过渡属性:
color, background-color
opacity
transform (包括 translate, scale, rotate 等)
width, height
margin, padding
border 相关属性

.element {
  transition-property: opacity, transform;
  /* 或者 */
  transition-property: all; /* 所有可过渡属性 */
}
  1. transition-duration(必需)
    定义过渡效果持续时间
.element {
  transition-duration: 0.3s; /* 可以是秒(s)或毫秒(ms) */
}
  1. transition-timing-function
    定义过渡效果的速度曲线
    描述
    ease默认值,慢快慢
    linear匀速
    ease-in慢开始
    ease-out慢结束
    ease-in-out慢开始和结束
    cubic-bezier(n,n,n,n)自定义贝塞尔曲线
    steps(n)分步过渡
.element {
  transition-timing-function: cubic-bezier(0.68, -0.55, 0.27, 1.55);
}
  1. transition-delay(可选)
    定义过渡效果开始前的延迟时间
.element {
  transition-delay: 0.2s; /* 0.2秒后开始过渡 */
}

案例实践:

//状态驱动的动画
<template>
	<div
	   @mousemove="onMousemove"
	   :style="{ backgroundColor: `hsl(${x}, 80%, 50%)` }"
	   class="movearea"
	>
		<p>Move your mouse across this div...</p>
		<p>x: {{ x }}</p>
	</div>
</template>

<script setup>
import { ref } from 'vue'
const x = ref(0)
const onMousemove = (e) => {
    x.value = e.clientX
}
</script>

<style scoped>
.movearea {
    transition: 0.3s background-color ease;
}
</style>

transform

transform 是 CSS 中用于对元素进行 2D 或 3D 变换的强大属性,它可以改变元素的形状、位置和方向而不影响文档流。

可以组合多个变换函数,空格分隔,从右向左依次执行

transform: rotate(45deg) scale(1.2) translateX(50px);
/* 先平移 → 然后缩放 → 最后旋转 */

2D

  1. 位移(Translate)
transform: translateX(50px);     /* 水平移动 */
transform: translateY(-20px);    /* 垂直移动 */
transform: translate(50px, 20px); /* 同时XY移动 */
  1. 旋转(Rotate)
transform: rotate(45deg);       /* 顺时针旋转45度 */
transform: rotate(-90deg);      /* 逆时针旋转90度 */
  1. 缩放(Scale)
transform: scale(1.5);          /* 均匀放大1.5倍 */
transform: scaleX(0.5);         /* 水平缩小一半 */
transform: scaleY(1.2);         /* 垂直放大1.2倍 */
transform: scale(1.2, 0.8);     /* 水平放大,垂直缩小 */
  1. 倾斜(Skew)
transform: skewX(15deg);        /* 水平倾斜 */
transform: skewY(-10deg);       /* 垂直倾斜 */
transform: skew(15deg, -10deg); /* 同时XY倾斜 */

3D

  1. 3D位移
transform: translateZ(100px);     /* Z轴移动 */
transform: translate3d(50px, 20px, 100px); /* XYZ移动 */
  1. 3D旋转
transform: rotateX(45deg);       /* 绕X轴旋转 */
transform: rotateY(30deg);       /* 绕Y轴旋转 */
transform: rotateZ(15deg);       /* 绕Z轴旋转 */
transform: rotate3d(1, 1, 0, 45deg); /* 自定义轴旋转 */
  1. 3D缩放
transform: scaleZ(1.5);         /* Z轴缩放 */
transform: scale3d(1.2, 1.2, 1.5); /* XYZ缩放 */
  1. 透视(Perspective)
transform: perspective(500px) rotateY(45deg);

指定观察者与 z=0 平面的距离
值越小,透视效果越强(类似广角镜头)
值越大,透视效果越弱(类似长焦镜头)
必须为正数

相关属性

  1. transform-origin
    设置变换的基准点(默认是元素中心)
transform-origin: 50% 50%;     /* 默认值 */
transform-origin: left top;    /* 左上角 */
transform-origin: 20px 30px;   /* 具体坐标 */
transform-origin: bottom right 50px; /* 3D变换时Z轴 */
  1. transform-style
    指定子元素是否保留3D位置
transform-style: flat;         /* 默认,子元素不保留3D位置 */
transform-style: preserve-3d;  /* 子元素保留3D位置 */
  1. perspective
    设置3D变换的视距
perspective: 1000px;          /* 在父元素上设置 */
  1. backface-visibility
    定义元素背面是否可见
backface-visibility: visible;  /* 默认,背面可见 */
backface-visibility: hidden;   /* 背面不可见 */

案例实践:

//3d翻转卡片
<template>
    <div class="flip-container">
        <div class="flipper">
            <div class="front">正面</div>
            <div class="back">背面</div>
        </div>
    </div>
</template>

<style scoped>
.flip-container {
    perspective: 100px;
    background: #644a68;
}
.flipper {
    transition: transform 3s;
    transform-style: preserve-3d;
    font-size: 30px;
}
.flip-container:hover .flipper {
    transform: rotateY(180deg);
}
.front,
.back {
    backface-visibility: hidden;
}
.back {
    transform: rotateY(180deg);
}
</style>

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

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

相关文章

MATLAB2024a超详细图文安装教程(2025最新版保姆级教程)附安装钥

目录 前言 一、MATLAB下载 二、MATLAB安装 二、MATLAB启动 前言 MATLAB&#xff08;Matrix Laboratory&#xff09;是由MathWorks公司开发的一款高性能的编程语言和交互式环境&#xff0c;主要用于数值计算、数据分析和算法开发。内置数学函数和工具箱丰富&#xff0c;开发…

基于 Spring Boot 瑞吉外卖系统开发(二)

基于 Spring Boot 瑞吉外卖系统开发&#xff08;二&#xff09; 员工登录功能实现 员工登录页面login.html存放在/resources/backend/page/login目录下。 启动项目&#xff0c;在浏览器中通过地址“http://localhost:8080/backend/page/login/login.html”访问员工登录页面。…

软考系统架构设计师之大数据与人工智能笔记

一、大数据架构设计 1. 核心概念与挑战 大数据特征&#xff1a;体量大&#xff08;Volume&#xff09;、多样性&#xff08;Variety&#xff09;、高速性&#xff08;Velocity&#xff09;、价值密度低&#xff08;Value&#xff09;。传统数据库问题&#xff1a;数据过载、性…

146. LRU 缓存 带TTL的LRU缓存实现(拓展)

LRU缓存 方法一:手动实现双向链表 哈希表 struct Node{int val;int key;Node* prev;Node* next;Node(int a, int b): key(a), val(b), prev(nullptr), next(nullptr) {}Node():key(0), val(0), prev(nullptr), next(nullptr) {} }; class LRUCache { private:Node* removeTai…

浅层神经网络:全面解析(扩展)

浅层神经网络&#xff1a;全面解析&#xff08;扩展&#xff09; 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;可以分享一下给大家。点击跳转到网站。 https://www.captainbed.cn/ccc 一、神经网络架构演进图谱 #mermaid-svg-…

Qt 事件系统负载测试:深入理解 Qt 事件处理机制

Qt 事件系统负载测试&#xff1a;深入理解 Qt 事件处理机制 文章目录 Qt 事件系统负载测试&#xff1a;深入理解 Qt 事件处理机制摘要引言实现原理1. 自定义事件类型2. 事件队列管理3. 性能指标监控4. 事件发送机制 性能监控实现1. 负载计算2. 内存监控3. 延迟计算 使用效果优化…

Unity3D仿星露谷物语开发33之光标位置可视化

1、目标 当从道具栏中拖出一个道具到地面的时候&#xff0c;光标区域会显示是否可放置物体的可视化显示。绿色表示可以放置物体&#xff0c;红色表示不可以放置物体。 2、优化InventoryManager脚本 添加2个方法&#xff1a; /// <summary>/// Returns the itemDetails&…

蓝桥杯冲刺题单--二分

二分 知识点 二分&#xff1a; 1.序列二分&#xff1a;在序列中查找&#xff08;不怎么考&#xff0c;会比较难&#xff1f;&#xff09; 序列二分应用的序列必须是递增或递减&#xff0c;但可以非严格 只要r是mid-1&#xff0c;就对应mid&#xff08;lr1&#xff09;/2 2.答…

MySQL原理(一)

目录 一、理解MySQL的服务器与客户端关系 1&#xff1a;MySQL服务器与客户端 2&#xff1a;服务器处理客户端请求 3&#xff1a;常见的存储引擎 二、字符集和比较规则 1&#xff1a;字符集和比较规则简介 2&#xff1a;字符集和比较规则应用 3&#xff1a;乱码原因&…

Docker+Jenkins+Gitee自动化项目部署

前置条件 docker安装成功 按照下面配置加速 sudo mkdir -p /etc/docker sudo tee /etc/docker/daemon.json <<-EOF {"registry-mirrors": ["https://register.librax.org"] } EOF sudo systemctl daemon-reload sudo systemctl restart docker一、…

VScode 画时序图(FPGA)

1、先安装插件&#xff1a; 2、然后就可以编写一个.js文件&#xff0c;如下&#xff1a; {signal: [{name: clk, wave: p.......|..},{name: rstn, wave: 01......|..},{name: din_vld, wave: 0.1.0...|..},{name: din, wave: "x.x...|..", data: ["D0", …

一文详解OpenCV环境搭建:Windows使用CLion配置OpenCV开发环境

在计算机视觉和图像处理领域&#xff0c;OpenCV 是一个不可或缺的工具。其为开发者提供了一系列广泛的算法和实用工具&#xff0c;支持多种编程语言&#xff0c;并且可以在多个平台上运行。对于希望在其项目中集成先进视觉功能的开发者来说&#xff0c;掌握如何配置和使用OpenC…

计算机网络 3-2 数据链路层(流量控制与可靠传输机制)

3.4 流量控制与可靠传输机制 流量控制&#xff1a;指由接收方控制发送方的发送速率&#xff0c;使接收方有足够的缓冲空间来接收每个帧 滑动窗口流量控制:一种更高效的流量控制方法。 在任意时刻&#xff0c;发送方都维持一组连续的允许发送帧的序号&#xff0c;称为发送窗口…

Jenkins配置的JDK,Maven和Git

1. 前置 在配置前&#xff0c;我们需要先把JDK&#xff0c;Maven和Git安装到Jenkins的服务器上。 &#xff08;1&#xff09;需要进入容器内部&#xff0c;执行命令&#xff1a;docker exec -u root -it 容器号/容器名称&#xff08;2选1&#xff09; bash -- 容器名称 dock…

有效压缩 Hyper-v linux Centos 的虚拟磁盘 VHDX

参考&#xff1a; http://www.360doc.com/content/22/0505/16/67252277_1029878535.shtml VHDX 有个不好的问题就是&#xff0c;如果在里面存放过文件再删除&#xff0c;那么已经使用过的空间不会压缩&#xff0c;导致空间一直被占用。那么就需要想办法压缩空间。 还有一点&a…

网络空间安全(53)XSS

一、定义与原理 XSS&#xff08;Cross Site Scripting&#xff09;&#xff0c;全称为跨站脚本攻击&#xff0c;是一种网站应用中的安全漏洞攻击。其原理是攻击者利用网站对用户输入内容校验不严格等漏洞&#xff0c;将恶意脚本&#xff08;通常是JavaScript&#xff0c;也可以…

Spring MVC 框架 的核心概念、组件关系及流程的详细说明,并附表格总结

以下是 Spring MVC 框架 的核心概念、组件关系及流程的详细说明&#xff0c;并附表格总结&#xff1a; 1. 核心理念 Spring MVC 是基于 MVC&#xff08;Model-View-Controller&#xff09;设计模式 的 Web 框架&#xff0c;其核心思想是 解耦&#xff1a; Model&#xff1a;数…

金融数据分析(Python)个人学习笔记(6):安装相关软件

python环境的安装请查看Python个人学习笔记&#xff08;1&#xff09;&#xff1a;Python软件的介绍与安装 一、pip 在windows系统中检查是否安装了pip 打开命令提示符的快捷键&#xff1a;winR&#xff0c;然后输入cmd 在命令提示符中执行如下命令 python -m pip --version…

一周学会Pandas2 Python数据处理与分析-Pandas2一维数据结构-Series

锋哥原创的Pandas2 Python数据处理与分析 视频教程&#xff1a; 2025版 Pandas2 Python数据处理与分析 视频教程(无废话版) 玩命更新中~_哔哩哔哩_bilibili Pandas提供Series和DataFrame作为数组数据的存储框架。 Series&#xff08;系列、数列、序列&#xff09;是一个带有…

DApp实战篇:前端技术栈一览

前言 在前面一系列内容中&#xff0c;我们由浅入深地了解了DApp的组成&#xff0c;从本小节开始我将带领大家如何完成一个完整的DApp。 本小节则先从前端开始。 前端技术栈 在前端开发者速入&#xff1a;DApp中的前端要干些什么&#xff1f;文中我说过&#xff0c;即便是在…