纯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使用示例
Oct 18 HTML / CSS
css3实现元素环绕中心点布局的方法示例
Jan 15 HTML / CSS
使用phonegap检测网络状态的方法
Mar 30 HTML / CSS
HTML5 对各个标签的定义与规定:body的介绍
Jun 21 HTML / CSS
HTML5之SVG 2D入门6—视窗坐标系与用户坐标系及变换概述
Jan 30 HTML / CSS
HTML5新增加标签和功能概述
Sep 05 HTML / CSS
微信小程序“圣诞帽”的实现思路详解
Dec 28 HTML / CSS
手把手教你实现一个canvas智绘画板的方法
Mar 04 HTML / CSS
HTML5去掉输入框type为number时的上下箭头的实现方法
Jan 03 HTML / CSS
html5响应式开发自动计算fontSize的方法
Jan 13 HTML / CSS
分享几个实用的CSS代码块
Jun 10 HTML / CSS
css清除浮动clearfix:after的用法详解(附完整代码)
May 21 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
php 数组动态添加实现代码(最土团购系统的价格排序)
2011/12/30 PHP
php中ob_flush函数和flush函数用法分析
2015/03/18 PHP
php版微信支付api.mch.weixin.qq.com域名解析慢原因与解决方法
2016/10/12 PHP
解密效果
2006/06/23 Javascript
刷新时清空文本框内容的js代码
2007/04/23 Javascript
Extjs ajax同步请求时post方式参数发送方式
2009/08/05 Javascript
根据鼠标的位置动态的控制层的位置
2009/11/24 Javascript
Jquery Ajax学习实例 向页面发出请求,返回XML格式数据
2010/03/14 Javascript
动态加载jQuery的方法
2015/06/16 Javascript
JavaScript之AOP编程实例
2015/07/17 Javascript
简单的JS轮播图代码
2016/07/18 Javascript
详解照片瀑布流效果(js,jquery分别实现与知识点总结)
2017/01/01 Javascript
js中switch语句的学习笔记
2020/03/25 Javascript
js实现上传按钮并显示缩略图小轮子
2020/05/04 Javascript
vue实现简易的双向数据绑定
2020/12/29 Vue.js
[15:39]教你分分钟做大人:龙骑士
2014/10/30 DOTA
Python读取一个目录下所有目录和文件的方法
2016/07/15 Python
Python实现判断一个字符串是否包含子串的方法总结
2017/11/21 Python
如何用Python合并lmdb文件
2018/07/02 Python
Python小工具之消耗系统指定大小内存的方法
2018/12/03 Python
Python设计模式之备忘录模式原理与用法详解
2019/01/15 Python
python3去掉string中的标点符号方法
2019/01/22 Python
python实现学员管理系统
2019/02/26 Python
Python学习笔记之字符串和字符串方法实例详解
2019/08/22 Python
HTC VIVE美国官网:VR虚拟现实眼镜
2018/02/13 全球购物
英国户外服装品牌:Craghoppers
2019/04/25 全球购物
宏碁西班牙官网:Acer西班牙
2021/01/08 全球购物
学前教育学生自荐信范文
2013/12/31 职场文书
加工操作管理制度
2014/01/19 职场文书
2014年文学毕业生自我鉴定
2014/04/23 职场文书
祖国在我心中演讲稿200字
2014/08/28 职场文书
个人投资合作协议书
2014/10/12 职场文书
2014大学生学生会工作总结
2014/12/19 职场文书
司机岗位职责范本
2015/04/10 职场文书
七年级思品教学反思
2016/02/20 职场文书
Java实现超大Excel文件解析(XSSF,SXSSF,easyExcel)
2022/07/15 Java/Android