0

0

使用CSS动画为HTML元素创建震动效果教程

花韻仙語

花韻仙語

发布时间:2025-11-10 09:24:18

|

286人浏览过

|

来源于php中文网

原创

使用CSS动画为HTML元素创建震动效果教程

本教程详细讲解如何利用css的`@keyframes`规则和`animation`属性,为html元素实现逼真的震动视觉效果。文章将涵盖动画定义、属性配置、以及通过javascript动态触发动画的方法,并提供完整的示例代码和注意事项,帮助开发者轻松为网页增添交互性。

1. 理解CSS动画核心:@keyframes与animation

CSS动画主要通过两个核心概念实现:@keyframes规则和animation属性。

  • @keyframes规则:用于定义动画序列的各个阶段。您可以在其中指定动画在不同时间点(通常以百分比表示,从0%到100%)的CSS属性值。这些属性值之间的过渡将由浏览器平滑地完成。
  • animation属性:用于将一个或多个@keyframes动画应用到HTML元素上。它是一个简写属性,可以设置动画的名称、持续时间、时间函数、延迟、迭代次数、方向、填充模式和播放状态。

通过组合这两者,我们可以创建从简单的悬停效果到复杂页面过渡的各种动态视觉体验。

2. 定义震动动画序列

震动效果通常涉及元素的微小位移(translate)和旋转(rotate),以模拟不规则的晃动。以下是一个经典的震动效果@keyframes定义:

@keyframes shake {
  0% { transform: translate(1px, 1px) rotate(0deg); }
  10% { transform: translate(-1px, -2px) rotate(-1deg); }
  20% { transform: translate(-3px, 0px) rotate(1deg); }
  30% { transform: translate(3px, 2px) rotate(0deg); }
  40% { transform: translate(1px, -1px) rotate(1deg); }
  50% { transform: translate(-1px, 2px) rotate(-1deg); }
  60% { transform: translate(-3px, 1px) rotate(0deg); }
  70% { transform: translate(3px, 1px) rotate(-1deg); }
  80% { transform: translate(-1px, -1px) rotate(1deg); }
  90% { transform: translate(1px, 2px) rotate(0deg); }
  100% { transform: translate(1px, -2px) rotate(-1deg); }
}

在这个@keyframes shake定义中:

立即学习前端免费学习笔记(深入)”;

  • 我们定义了动画从0%到100%的十一个关键帧。
  • 每个关键帧都使用了transform属性来同时改变元素的translate(位移)和rotate(旋转)值。
  • translate(x, y) 使元素在水平和垂直方向上移动。
  • rotate(deg) 使元素旋转指定的角度。
  • 通过在不同百分比处设置微小且不规则的位移和旋转,我们创建了一种随机晃动的视觉效果。

3. 应用动画属性

为了实现可控的震动效果(例如持续3秒),我们需要在CSS中定义一个类,将@keyframes shake动画应用到目标元素上。

.shake-active {
  animation-name: shake; /* 指定要使用的 @keyframes 动画名称 */
  animation-duration: 3s; /* 动画持续时间为3秒 */
  animation-timing-function: ease-in-out; /* 动画速度曲线,可根据需要调整 */
  animation-iteration-count: 1; /* 动画播放次数为1次 */
  animation-fill-mode: forwards; /* 动画结束后保持最后一个关键帧的样式 */
}

/* 示例元素的样式,非震动效果必需 */
#myElement {
  background-color: lightcoral;
  height: 150px;
  width: 150px;
  margin: 50px;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 1.2em;
  color: white;
  font-weight: bold;
}
  • animation-name: shake;: 引用我们之前定义的@keyframes shake动画。
  • animation-duration: 3s;: 设置动画总时长为3秒,满足了3秒最大持续时间的要求。
  • animation-timing-function: ease-in-out;: 定义动画的速度曲线,这里使用先加速后减速,使震动感觉更自然。
  • animation-iteration-count: 1;: 确保动画只播放一次。如果需要无限循环,可以设置为infinite。
  • animation-fill-mode: forwards;: 动画结束后,元素会保持其在动画最后一个关键帧时的样式,而不是立即回到初始状态。这对于一些动画效果可能很重要。

4. 动态触发震动效果

要实现“像函数一样随时调用”震动效果,我们可以结合JavaScript来动态添加和移除包含动画属性的CSS类。

魔珐星云
魔珐星云

无需昂贵GPU,一键解锁超写实/二次元等多风格3D数字人,跨端适配千万级并发的具身智能平台。

下载
function triggerShake(elementId) {
  const element = document.getElementById(elementId);
  if (element) {
    // 确保在重新添加类之前移除旧的动画类,以允许动画再次播放
    element.classList.remove('shake-active');
    // 强制浏览器重绘以重置动画(通过获取一个属性)
    void element.offsetWidth;
    // 添加类以触发动画
    element.classList.add('shake-active');

    // 动画结束后移除类,以便下次可以再次触发
    // 注意:这里的3000ms应与CSS中的animation-duration匹配
    setTimeout(() => {
      element.classList.remove('shake-active');
    }, 3000);
  }
}

这段JavaScript代码的工作原理:

  1. triggerShake(elementId) 函数接收一个元素的ID。
  2. 它首先移除shake-active类,这是为了确保如果元素已经在震动或刚震动完,可以重新触发动画。
  3. void element.offsetWidth; 这一行是一个小技巧,强制浏览器重新计算元素的布局,从而“重置”动画状态,使得即使类被立即添加回来,动画也能从头开始播放。
  4. 然后,它添加shake-active类,这会立即应用CSS动画并开始震动。
  5. setTimeout 函数在3000毫秒(即动画持续时间)后移除shake-active类。这确保了动画只播放一次,并且元素在动画结束后恢复到没有震动效果的状态,为下一次触发做好准备。

5. 完整示例代码

将HTML、CSS和JavaScript结合起来,形成一个完整的可运行示例:




  
  
  HTML元素震动效果教程
  



  

HTML元素震动效果演示

点击按钮震动我

6. 拓展与注意事项

全屏震动效果

如果目标是让整个HTML窗口看起来震动,可以将shake-active类应用到

元素,或者创建一个覆盖整个视口的div并对其应用动画。
/* 应用于body的全屏震动 */
body.shake-active {
  animation-name: shake;
  animation-duration: 3s;
  animation-timing-function: ease-in-out;
  animation-iteration-count: 1;
  animation-fill-mode: forwards;
}

然后通过JavaScript document.body.classList.add('shake-active'); 来触发。

性能考量

CSS transform属性(包括translate和rotate)的动画通常是高性能的,因为它们可以通过GPU加速。这意味着它们不会引起布局或绘制的重排,从而提供更流畅的动画体验。避免对width, height, margin, padding等属性进行动画,这些属性会触发昂贵的布局计算。

用户体验与无障碍性

  • 适度使用:震动效果应谨慎使用,过度或频繁的震动可能会分散用户注意力,甚至引起不适。
  • 提供控制:对于长时间或剧烈的动画,考虑提供一个选项让用户可以停止或禁用动画,特别是对于有前庭系统敏感性或运动障碍的用户。
  • 媒体查询:可以使用@media (prefers-reduced-motion)媒体查询来检测用户是否偏好减少动画,并相应地调整或禁用震动效果。

动画持续时间与迭代

  • animation-duration:根据所需效果调整动画持续时间。较短的时间会产生更急促的震动,较长的时间则更平缓。
  • animation-iteration-count:设置为1表示播放一次,设置为infinite表示无限循环。通过JavaScript动态控制类,可以灵活实现单次播放或多次播放。

7. 总结

通过本教程,您已经掌握了如何使用CSS的@keyframes规则和animation属性来创建HTML元素的震动效果,并学会了如何结合JavaScript动态地触发和控制这些动画。这种方法不仅功能强大,而且性能优异,是为网页添加丰富交互性和视觉反馈的有效手段。在实际应用中,请务必考虑用户体验和无障碍性,以提供最佳的浏览体验。

相关专题

更多
js获取数组长度的方法
js获取数组长度的方法

在js中,可以利用array对象的length属性来获取数组长度,该属性可设置或返回数组中元素的数目,只需要使用“array.length”语句即可返回表示数组对象的元素个数的数值,也就是长度值。php中文网还提供JavaScript数组的相关下载、相关课程等内容,供大家免费下载使用。

553

2023.06.20

js刷新当前页面
js刷新当前页面

js刷新当前页面的方法:1、reload方法,该方法强迫浏览器刷新当前页面,语法为“location.reload([bForceGet]) ”;2、replace方法,该方法通过指定URL替换当前缓存在历史里(客户端)的项目,因此当使用replace方法之后,不能通过“前进”和“后退”来访问已经被替换的URL,语法为“location.replace(URL) ”。php中文网为大家带来了js刷新当前页面的相关知识、以及相关文章等内容

374

2023.07.04

js四舍五入
js四舍五入

js四舍五入的方法:1、tofixed方法,可把 Number 四舍五入为指定小数位数的数字;2、round() 方法,可把一个数字舍入为最接近的整数。php中文网为大家带来了js四舍五入的相关知识、以及相关文章等内容

731

2023.07.04

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

477

2023.09.01

JavaScript转义字符
JavaScript转义字符

JavaScript中的转义字符是反斜杠和引号,可以在字符串中表示特殊字符或改变字符的含义。本专题为大家提供转义字符相关的文章、下载、课程内容,供大家免费下载体验。

394

2023.09.04

js生成随机数的方法
js生成随机数的方法

js生成随机数的方法有:1、使用random函数生成0-1之间的随机数;2、使用random函数和特定范围来生成随机整数;3、使用random函数和round函数生成0-99之间的随机整数;4、使用random函数和其他函数生成更复杂的随机数;5、使用random函数和其他函数生成范围内的随机小数;6、使用random函数和其他函数生成范围内的随机整数或小数。

990

2023.09.04

如何启用JavaScript
如何启用JavaScript

JavaScript启用方法有内联脚本、内部脚本、外部脚本和异步加载。详细介绍:1、内联脚本是将JavaScript代码直接嵌入到HTML标签中;2、内部脚本是将JavaScript代码放置在HTML文件的`<script>`标签中;3、外部脚本是将JavaScript代码放置在一个独立的文件;4、外部脚本是将JavaScript代码放置在一个独立的文件。

656

2023.09.12

Js中Symbol类详解
Js中Symbol类详解

javascript中的Symbol数据类型是一种基本数据类型,用于表示独一无二的值。Symbol的特点:1、独一无二,每个Symbol值都是唯一的,不会与其他任何值相等;2、不可变性,Symbol值一旦创建,就不能修改或者重新赋值;3、隐藏性,Symbol值不会被隐式转换为其他类型;4、无法枚举,Symbol值作为对象的属性名时,默认是不可枚举的。

551

2023.09.20

Golang gRPC 服务开发与Protobuf实战
Golang gRPC 服务开发与Protobuf实战

本专题系统讲解 Golang 在 gRPC 服务开发中的完整实践,涵盖 Protobuf 定义与代码生成、gRPC 服务端与客户端实现、流式 RPC(Unary/Server/Client/Bidirectional)、错误处理、拦截器、中间件以及与 HTTP/REST 的对接方案。通过实际案例,帮助学习者掌握 使用 Go 构建高性能、强类型、可扩展的 RPC 服务体系,适用于微服务与内部系统通信场景。

6

2026.01.15

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.9万人学习

CSS教程
CSS教程

共754课时 | 19万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号