纯html+css实现打字效果


Posted in HTML / CSS onAugust 02, 2021

本文主要介绍了纯html+css实现打字效果,具有一定的参考价值,感兴趣的可以了解一下

效果图

纯html+css实现打字效果

分析
 

可以将动画看做三个不同的层次:

  • 最底层的文字
  • 中间挡住文字的背景
  • 最上层的光标

文字是静止的,而中间的背景和最上层的光标是动态的。
初始时,背景挡住所有的文字,光标在最左边。
动画进行时,背景和光标以相同的步伐从左往右移动。
动画结束时,背景不再遮挡文字,光标则在最右边闪烁。

纯html+css实现打字效果

代码
 

html
 

<div class="text">hello,world!</div>

css
 

:root {
    /* 字符数量 */
    --steps: 12;
    /* 动画时间 */
    --duration: 2.5s;
    /* 字体大小 */
    --fontSize: 50px;
    /* 光标大小 */
    --cursorSize: 20px;
}

.text {
    color: #333;;
    position: relative;
    display: inline-block;
    font-family: 'Courier New', Courier, monospace;
    font-size: var(--fontSize);
    line-height: 1;
}

.text::after {
    content: '';
    width: var(--cursorSize);
    height: var(--fontSize);
    background-color: black;
    z-index: 2;
    position: absolute;
    animation: blink 1s var(--duration) step-end infinite,
               moveCursor var(--duration) steps(var(--steps)) forwards;
}

.text::before {
    content: '';
    width: 100%;
    height: var(--fontSize);
    z-index: 1;
    position: absolute;
    background: linear-gradient(#fff, #fff) no-repeat top right;
    animation: showText var(--duration) steps(var(--steps)) forwards;
}

/* 光标闪烁动画 */
@keyframes blink {
    0% {
        background-color: black;
    }
    50% {
        background-color: transparent;
    }
    100% {
        background-color: black;
    }
}

/* 光标移动动画 */
@keyframes moveCursor {
    0% {
        left: 0%;
    }
    100% {
        left: 100%;
    }
}

/* 背景移动动画 */
@keyframes showText {
    0% {
        background-size: 100% 100%;
    }
    100% {
        background-size: 0% 100%;
    }
}

注意
字体必须是等宽字体。因为光标每次移动的距离是是根据字符的数量 / 总宽度来决定的。
 

在线演示
 

到此这篇关于纯html+css实现打字效果的文章就介绍到这了,更多相关html css打字效果内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章,希望大家以后多多支持三水点靠木!

 
HTML / CSS 相关文章推荐
深入浅出CSS3 background-clip,background-origin和border-image教程
Jan 27 HTML / CSS
CSS3 text-shadow实现文字阴影效果
Feb 24 HTML / CSS
CSS3实现各种图形的示例代码
Oct 19 HTML / CSS
CSS3动画特效在活动页中的应用
Jan 21 HTML / CSS
基于CSS3的animation属性实现微信拍一拍动画效果
Jun 22 HTML / CSS
详解H5本地储存Web Storage
Jul 03 HTML / CSS
程序设计HTML5 Canvas API
Apr 08 HTML / CSS
详解HTML5中的manifest缓存使用
Sep 09 HTML / CSS
HTML5+WebSocket实现多文件同时上传的实例
Dec 29 HTML / CSS
如何给HTML标签中的文本设置修饰线
Nov 18 HTML / CSS
Css预编语言及区别详解
Apr 25 HTML / CSS
什么是css原子化,有什么用?
Apr 24 HTML / CSS
html form表单基础入门案例讲解
Jul 21 #HTML / CSS
带你了解CSS基础知识,样式
Jul 21 #HTML / CSS
CSS实现隐藏搜索框功能(动画正反向序列)
Jul 21 #HTML / CSS
详解CSS3.0(Cascading Style Sheet) 层叠级联样式表
html5实现点击弹出图片功能
Jul 16 #HTML / CSS
纯CSS3实现div按照顺序出入效果
CSS3中Animation实现简单的手指点击动画的示例
You might like
15个小时----从修改程序到自己些程序
2006/10/09 PHP
php fckeditor 调用的函数
2009/06/21 PHP
php利用fsockopen GET/POST提交表单及上传文件
2017/05/22 PHP
慎用 somefunction.prototype 分析
2009/06/02 Javascript
图像替换新技术 状态域方法
2010/01/28 Javascript
IE6背景图片不缓存问题解决方案及图片使用策略多个方法小结
2012/05/14 Javascript
jquery动态添加删除div 具体实现
2013/07/20 Javascript
一个奇葩的最短的 IE 版本判断JS脚本
2014/05/28 Javascript
充分发挥Node.js程序性能的一些方法介绍
2015/06/23 Javascript
Angular 理解module和injector,即依赖注入
2016/09/07 Javascript
vue解决跨域路由冲突问题思路解析
2017/11/03 Javascript
详解nodejs 配置文件处理方案
2019/01/02 NodeJs
用vscode开发vue应用的方法步骤
2019/05/06 Javascript
vue实现多级菜单效果
2019/10/19 Javascript
Node.js 深度调试方法解析
2020/07/28 Javascript
详解Howler.js Web音频播放终极解决方案
2020/08/23 Javascript
[01:18:35]DOTA2-DPC中国联赛 正赛 Elephant vs LBZS BO3 第一场 1月29日
2021/03/11 DOTA
详解python多线程之间的同步(一)
2019/04/03 Python
python做反被爬保护的方法
2019/07/01 Python
Python线上环境使用日志的及配置文件
2019/07/28 Python
基于Python执行dos命令并获取输出的结果
2019/12/30 Python
Tensorflow: 从checkpoint文件中读取tensor方式
2020/02/10 Python
Python Selenium 设置元素等待的三种方式
2020/03/18 Python
TensorFlow2.1.0安装过程中setuptools、wrapt等相关错误指南
2020/04/08 Python
聊聊python中的循环遍历
2020/09/07 Python
浅谈HTML5 Web Worker的使用
2018/01/05 HTML / CSS
选购世界上最好的美妆品:Cult Beauty
2017/11/03 全球购物
Nisbets法国:英国最大的厨房和餐饮设备供应商
2019/03/18 全球购物
乡镇纠风工作实施方案
2014/03/22 职场文书
干部考察材料范文
2014/12/24 职场文书
确保工程质量承诺书
2015/04/29 职场文书
学生检讨书怎么写
2015/05/07 职场文书
2016优秀大学生个人事迹材料范文
2016/03/01 职场文书
教你解决往mysql数据库中存入汉字报错的方法
2021/05/06 MySQL
php去除数组中为0的元素的实例分析
2021/11/17 PHP
高并发下Redis如何保持数据一致性(避免读后写)
2022/03/18 Redis