新闻中心
如何通过键盘按键控制CSS动画的播放与暂停

本教程详细介绍了如何利用j*ascript的键盘事件(keydown和keyup)来动态控制css动画的播放和暂停状态。我们将学习如何配置css动画使其无限循环并初始暂停,并通过j*ascript监听用户按键行为,实现按键时动画运行、松开按键时动画暂停的交互效果。
在现代网页设计中,动画是提升用户体验的重要元素。CSS动画提供了一种声明式的方式来创建复杂的动画效果,而J*aScript则能赋予这些动画更强大的交互性。本文将深入探讨如何结合CSS和J*aScript,实现通过键盘按键来精确控制动画的播放与暂停。
一、CSS动画基础与初始配置
要实现通过按键控制的动画,首先需要定义动画本身,并设置其初始状态。
1. 定义关键帧动画 (@keyframes)
使用@keyframes规则定义动画的各个阶段。每个关键帧(如0%、50%、100%)都定义了元素在该时间点的样式。
@keyframes rulle {
0%{
top: 40px;
left: 0;
transform: rotate(0deg);
}
12.5%{
top: 40px;
left: 50px;
transform: rotate(45deg);
}
25%{
top: 40px;
left: 100px;
transform: rotate(90deg);
}
37.5%{
top: 40px;
left: 150px;
transform: rotate(135deg);
}
50%{
top: 40px;
left: 200px;
transform: rotate(180deg);
}
62.5%{
top: 40px;
left: 250px;
transform: rotate(225deg);
}
75%{
top: 40px;
left: 300px;
transform: rotate(270deg);
}
87.5%{
top: 40px;
left: 350px;
transform: rotate(315deg);
}
100%{
top: 40px;
left: 250px; /* 动画结束时回到一个中间位置 */
transform: rotate(360deg);
}
}
@keyframes roter {
0%{ transform: rotate(0deg); }
25%{ transform: rotate(90deg); }
50%{ transform: rotate(180deg); }
75%{ transform: rotate(270deg); }
100%{ transform: rotate(360deg); }
}2. 应用动画并设置初始状态
将定义的动画应用到HTML元素上,并设置其播放属性。为了实现按键控制,我们需要:
- 无限循环 (animation-iteration-count: infinite):确保动画在播放时不会只运行一次。
- 初始暂停 (animation-play-state: paused):在页面加载时动画不自动播放。
这些属性可以通过animation缩写属性或单独的属性来设置。
#ball {
/* ... 其他样式 ... */
animation: rulle 4s infinite linear; /* 应用rulle动画,持续4秒,无限循环,线性速度 */
animation-play-state: paused; /* 初始状态为暂停 */
}
#roter {
/* ... 其他样式 ... */
animation: roter 4s linear infinite; /* 应用roter动画,持续4秒,无限循环,线性速度 */
animation-play-state: paused; /* 初始状态为暂停 */
}这里,infinite确保动画会持续播放,直到被暂停;paused则让动画在页面加载后不立即启动。
来画数字人|直播|
来画数字人自动化|直播|,无需请真人主播,即可实现24小时|直播|,无缝衔接各大|直播|平台。
57
查看详情
二、J*aScript事件监听与动画控制
通过J*aScript,我们可以监听用户的键盘操作,并根据按键状态来动态改变CSS动画的animation-play-state属性。
1. 监听keydown事件
当用户按下键盘上的任意键时,会触发keydown事件。我们可以在这个事件监听器中将动画的animation-play-state设置为running,从而启动动画。
2. 监听keyup事件
当用户松开键盘上的任意键时,会触发keyup事件。在这个事件监听器中,我们将animation-play-state设置回paused,从而暂停动画。
const ball = document.querySelector("#ball");
const roter = document.querySelector("#roter");
// 监听按键按下事件
window.addEventListener("keydown", () => {
ball.style.animationPlayState = "running"; // 启动 #ball 元素的动画
roter.style.animationPlayState = "running"; // 启动 #roter 元素的动画
});
// 监听按键松开事件
window.addEventListener("keyup", () => {
ball.style.animationPlayState = "paused"; // 暂停 #ball 元素的动画
roter.style.animationPlayState = "paused"; // 暂停 #roter 元素的动画
});这里,我们通过element.style.animationPlayState直接修改元素的内联样式,这种方式会覆盖CSS中定义的animation-play-state,从而实现动画的动态控制。
三、完整示例
下面是一个完整的HTML、CSS和J*aScript代码示例,展示了如何实现按住任意键播放动画,松开按键暂停动画的效果。
HTML结构 (index.html)
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>键盘控制CSS动画</title>
<link rel="stylesheet" href="style.css">
</head>
<body>
<div class="linje">
<div id="ball">
<p id="roter">动画元素</p>
</div>
</div>
<script src="script.js"></script>
</body>
</html>CSS样式 (style.css)
body {
display: flex;
justify-content: center;
align-items: center;
min-height: 100vh;
margin: 0;
background-color: #f0f0f0;
overflow: hidden; /* 防止动画溢出导致滚动条 */
}
.linje {
width: 1000px;
height: 500px;
border: 1px solid #ccc;
position: relative;
background-color: #fff;
}
#ball {
position: relative;
top: 40px;
left: 0;
width: 100px;
height: 100px;
background-color: rgb(114, 240, 214);
border-radius: 50%;
text-align: center;
line-height: 100px;
font-size: 14px;
color: #333;
display: flex;
justify-content: center;
align-items: center;
box-shadow: 0 4px 8px rgba(0,0,0,0.1);
/* 应用动画并设置初始状态 */
animation: rulle 4s infinite linear;
animation-play-state: paused;
}
@keyframes rulle {
0%{
top: 40px;
left: 0;
transform: rotate(0deg);
}
12.5%{
top: 40px;
left: 50px;
transform: rotate(45deg);
}
25%{
top: 40px;
left: 100px;
transform: rotate(90deg);
}
37.5%{
top: 40px;
left: 150px;
transform: rotate(135deg);
}
50%{
top: 40px;
left: 200px;
transform: rotate(180deg);
}
62.5%{
top: 40px;
left: 250px;
transform: rotate(225deg);
}
75%{
top: 40px;
left: 300px;
transform: rotate(270deg);
}
87.5%{
top: 40px;
left: 350px;
transform: rotate(315deg);
}
100%{
top: 40px;
left: 250px; /* 动画结束时回到一个中间位置 */
transform: rotate(360deg);
}
}
#roter {
/* #roter 元素本身的旋转动画 */
animation: roter 4s linear infinite;
animation-play-state: paused;
}
@keyframes roter {
0%{ transform: rotate(0deg); }
25%{ transform: rotate(90deg); }
50%{ transform: rotate(180deg); }
75%{ transform: rotate(270deg); }
100%{ transform: rotate(360deg); }
}J*aScript逻辑 (script.js)
const ball = document.querySelector("#ball");
const roter = document.querySelector("#roter");
// 监听按键按下事件,启动动画
window.addEventListe
ner("keydown", () => {
ball.style.animationPlayState = "running";
roter.style.animationPlayState = "running";
});
// 监听按键松开事件,暂停动画
window.addEventListener("keyup", () => {
ball.style.animationPlayState = "paused";
roter.style.animationPlayState = "paused";
});四、注意事项与总结
- animation-play-state属性:这是控制CSS动画播放/暂停的关键。通过J*aScript动态修改此属性,可以轻松实现动画的启停。
- animation-iteration-count: infinite:确保动画
以上就是如何通过键盘按键控制CSS动画的播放与暂停的详细内容,更多请关注其它相关文章!
# 是一个
# 推广饮料的营销计划
# 三水国外网站推广
# 长沙线上营销获客推广平台
# 新产品营销推广语术研究
# 宣城抖音关键词搜索排名
# 广州测绘公司网站建设
# 三亚seo在线咨询
# 许昌seo外包电话
# 黄石港抖音seo推广
# 郑州营销推广专业
# 相关文章
# 各大
# 加载
# 这是
# css
# 结束时
# 我们可以
# 在这个
# 按下
# html元素
# 键盘事件
# css样式
# css动画
# 网页设计
# win
# js
# html
# java
# javascript
相关栏目:
【
科技资讯46185 】
【
网络学院92790 】
相关推荐:
Spring Boot内嵌服务器与J*a EE全栈特性:选择与部署策略
火锅吃太多会怎样 火锅吃太多会上火吗
Golang切片为何属于引用类型_Golang slice底层结构与引用语义说明
wps文字怎么插入目录并自动更新_wps文字如何插入目录并自动更新方法
qq浏览器如何查看和导出已保存的密码 qq浏览器密码管理器数据备份教程
J*aScript中高效管理与清空动态列表:避免循环陷阱
解决Python单元测试中Mock异常方法调用计数为零的问题
PHP中高效并行检查多链接状态的教程
CSS实现侧边栏导航项全宽圆角悬停背景效果
Mudbox图层蒙版怎么用_Mudbox图层蒙版数字雕刻应用技巧
自定义Bag-of-Words实现:处理带负号的词汇权重
XML中包含HTML标签导致解析错误? 正确嵌入非XML数据的两种方法
在Socket.IO连接中实现Access Token自动更新与动态重连
抖音网页版平台入口 抖音网页版官网在线访问教程
C++如何解决segmentation fault_C++段错误调试与原因分析
漫蛙网页登录入口 漫蛙漫画官方授权网址
Django表单验证失败时保留用户输入数据的最佳实践
谷歌浏览器浏览体验优化_谷歌浏览器新版直连永久可用提示
抖音网页版快捷访问 抖音网页版网页版入口操作教程
163邮箱登录密码 163邮箱忘记密码找回
Excel如何用迷你图显趋势_Excel用迷你图显趋势【趋势小图】
Lar*el Excel导入时生成自定义递增ID的策略与实践
mcjs网页版在线存档 mcjs云存档登录入口
微博网页版主页入口 微博官方网站免登录访问
J*aScript中针对特定容器内图片动画的实现教程
支付宝碰一碰设备是REDMI手机吗 博主拆机辟谣:处理器、内存都不一样
12306选座系统怎么选连座_12306选座多人连坐操作方法
C++的std::forward_list怎么用_C++ STL中单向链表容器的特点与应用
Go Martini框架:动态服务解码后的图片内容
在Typer应用中优雅地处理和重组任意命令行参数
QQ邮箱网页版登录入口 QQ邮箱官方在线使用平台
凉拌黄瓜怎么拌更入味 凉拌黄瓜简单家常做法
Pandas DataFrame 多条件优先级排序与排名
实现全屏滚动与导航点:专业教程
汽水音乐在线解析 汽水音乐在线解析入口
汽水音乐车机版横屏版7.1 汽水音乐车机版横屏版下载入口
照顾宝贝2小游戏免费秒玩入口
QQ邮箱官方网站登录入口_QQ邮箱网页版在线使用
J*aScript数组对象转换:按指定键分组与值收集
拼多多赚钱渠道_拼多多收益来源
12306选座怎么选到商务座_12306商务座选择与配置说明
神庙逃亡小游戏在线玩 神庙逃亡小游戏入口
在Go开发中优雅管理ListenAndServe进程:GoSublime集成方案
CSS布局中意外空白:解决padding-top导致的顶部间距问题
中兴Axon42Ultra怎样在文件App筛图_iPhone中兴Axon42Ultra文件App筛图【图片筛选】
蛙漫安全无毒 官方认证的绿色入口
J*a应用集成GitHub CLI与API认证指南
Go语言中的*string:深入理解字符串指针
微博网页版首页入口 微博电脑端官网登录链接
TypeScript/J*aScript:高效查找数组中首个唯一ID对象


2025-12-13
浏览次数:次
返回列表
ner("keydown", () => {
ball.style.animationPlayState = "running";
roter.style.animationPlayState = "running";
});
// 监听按键松开事件,暂停动画
window.addEventListener("keyup", () => {
ball.style.animationPlayState = "paused";
roter.style.animationPlayState = "paused";
});