0

0

CSS过渡实现的打字机效果模拟_结合宽度与steps函数的创意

P粉602998670

P粉602998670

发布时间:2026-02-28 08:02:02

|

575人浏览过

|

来源于php中文网

原创

纯css打字机效果通过width动画+overflow:hidden截断+steps()分步实现,需等宽字体、禁换行、精确匹配字符数,动态适配依赖js或预处理器,且存在跨浏览器渲染差异。

css过渡实现的打字机效果模拟_结合宽度与steps函数的创意

为什么 width + steps() 能模拟打字机效果

纯 CSS 实现打字机效果,本质是让文字「逐字显现」。但 CSS 没有“字符级渲染控制”,所以得绕道:用 width0 动态展开容器,配合 overflow: hidden 截断内容,再用 steps() 让展开过程不平滑——每一步卡在整数宽度上,视觉上就接近“一个字、停顿、下一个字”。关键在于:steps(6, end) 中的 6 必须和文字总字符数严格对应(或略多),否则会漏字或卡住。

  • steps() 的第二个参数用 end(不是 start),否则首字符会延迟一帧才出现
  • 字体必须是等宽(font-family: monospace)或已知单字符宽度,否则 width 扩展无法对齐字数
  • 中文/Emoji 等非等宽字符会导致错位,此时应改用 ch 单位(1ch ≈ 数字 0 的宽度),而非 pxem

overflow: hiddenwhite-space: nowrap 缺一不可

只设 width 动画却没限制溢出,文字会直接撑开容器、根本看不到“打字”过程。而如果允许换行(默认 white-space: normal),动画过程中文字可能折行,导致宽度计算失效、steps() 步骤错乱。

  • 必须同时声明:overflow: hidden + white-space: nowrap
  • 父容器不能有 paddingborder 干扰宽度基准,否则动画起始点偏移
  • 若文本含空格或连字符,需额外加 word-break: keep-all 防止浏览器主动断词

如何适配不同长度文本而不重写动画

硬编码 steps(12) 只适用于固定 12 字文本。实际项目中,文本长度常变,手动改 steps() 值既脆弱又不可维护。可行解是用 CSS 自定义属性动态传入字数:

span {
  --char-count: 15;
  animation: type var(--char-count) * 0.25s steps(var(--char-count), end);
}
@keyframes type {
  from { width: 0; }
  to { width: calc(var(--char-count) * 1ch); }
}

但注意:calc() 里不能直接用 var(--char-count) 做乘法(CSS 不支持变量参与运算),所以上面写法仅示意逻辑。真实做法是 JS 注入样式,或用预处理器编译时计算。

Q.AI视频生成工具
Q.AI视频生成工具

支持一分钟生成专业级短视频,多种生成方式,AI视频脚本,在线云编辑,画面自由替换,热门配音媲美真人音色,更多强大功能尽在QAI

下载

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

  • 服务端渲染或构建时已知文本长度 → 用 PostCSS 或 SASS 动态生成 steps(N)width 终值
  • 客户端动态文本 → 用 JS 读取 textContent.length,设置 style.setProperty('--char-count', len),再触发重绘
  • 避免用 ch 单位计算中文宽度(1ch 对中文不准确),此时应测出该字体下中文平均宽度(如 18px),改用 px + JS 测量

动画卡顿、首帧闪动或末尾跳变的常见原因

看似简单的 CSS 动画,上线后常出现第一帧全显、中间卡两帧、最后一字突然弹出等问题。根因往往不在动画本身,而在渲染链路干扰。

  • 未加 will-change: width,尤其在低性能设备上,width 动画易掉帧
  • 父元素用了 transform(如 translateZ(0))创建新层叠上下文,导致子元素 overflow: hidden 失效
  • 动画结束时 width 设为 100%fit-content,而非精确值,造成末尾回弹
  • 字体加载完成前就执行动画 → 加 @font-facefont-display: block,或监听 document.fonts.load() 后再触发动画

最麻烦的是:不同浏览器对 steps() 的实现细节有差异,Safari 对小数值步长更敏感,Chrome 在 subpixel 渲染下偶有 1px 抖动。真要稳定,就得接受——它只是近似模拟,别指望像素级一致。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

1002

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

810

2023.11.06

Sass和less的区别
Sass和less的区别

Sass和less的区别有语法差异、变量和混合器的定义方式、导入方式、运算符的支持、扩展性等。本专题为大家提供Sass和less相关的文章、下载、课程内容,供大家免费下载体验。

212

2023.10.12

counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

200

2023.11.20

java中break的作用
java中break的作用

本专题整合了java中break的用法教程,阅读专题下面的文章了解更多详细内容。

120

2025.10.15

java break和continue
java break和continue

本专题整合了java break和continue的区别相关内容,阅读专题下面的文章了解更多详细内容。

260

2025.10.24

length函数用法
length函数用法

length函数用于返回指定字符串的字符数或字节数。可以用于计算字符串的长度,以便在查询和处理字符串数据时进行操作和判断。 需要注意的是length函数计算的是字符串的字符数,而不是字节数。对于多字节字符集,一个字符可能由多个字节组成。因此,length函数在计算字符串长度时会将多字节字符作为一个字符来计算。更多关于length函数的用法,大家可以阅读本专题下面的文章。

952

2023.09.19

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

528

2023.06.20

Golang 并发编程模型与工程实践:从语言特性到系统性能
Golang 并发编程模型与工程实践:从语言特性到系统性能

本专题系统讲解 Golang 并发编程模型,从语言级特性出发,深入理解 goroutine、channel 与调度机制。结合工程实践,分析并发设计模式、性能瓶颈与资源控制策略,帮助将并发能力有效转化为稳定、可扩展的系统性能优势。

2

2026.02.27

热门下载

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

精品课程

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

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.5万人学习

CSS教程
CSS教程

共754课时 | 37.1万人学习

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

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