纯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 优势以及网页设计师如何使用CSS3技术
Jul 29 HTML / CSS
纯css3实现的竖形无限级导航
Dec 10 HTML / CSS
纯CSS3打造属于自己的“小黄人”
Mar 14 HTML / CSS
使用CSS3实现SVG路径描边动画效果入门教程
Oct 21 HTML / CSS
详解HTML5通讯录获取指定多个人的信息
Dec 20 HTML / CSS
html5 svg 中元素点击事件添加方法
Jan 16 HTML / CSS
程序设计HTML5 Canvas API
Apr 08 HTML / CSS
HTML块级标签汇总(小篇)
Jul 13 HTML / CSS
html5 http的轮询和Websocket原理
Oct 19 HTML / CSS
完美实现CSS垂直居中的11种方法
Mar 27 HTML / CSS
CSS 实现多彩、智能的阴影效果
May 12 HTML / CSS
CSS3实现指纹特效代码
Mar 17 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基础教程 php内置函数实例教程
2012/08/21 PHP
PHP中字符串长度的截取用法示例
2017/01/12 PHP
PHP使用GD库制作验证码的方法(点击验证码或看不清会刷新验证码)
2017/08/15 PHP
PHP基于DateTime类解决Unix时间戳与日期互转问题【针对1970年前及2038年后时间戳】
2018/06/13 PHP
为Extjs加加速(javascript加速)
2010/08/19 Javascript
JavaScript中document.forms[0]与getElementByName区别
2015/01/21 Javascript
浅谈js常用内置方法和对象
2016/09/24 Javascript
js前端导出Excel的方法
2017/11/01 Javascript
图文介绍Vue父组件向子组件传值
2018/02/17 Javascript
vue 监听某个div垂直滚动条下拉到底部的方法
2018/09/15 Javascript
微信小程序下拉框功能的实例代码
2018/11/06 Javascript
vue实现短信验证码登录功能(流程详解)
2019/12/10 Javascript
如何区分vue中的v-show 与 v-if
2020/09/08 Javascript
nodejs处理tcp连接的核心流程
2021/02/26 NodeJs
[06:21]2014DOTA2国际邀请赛 庆祝VG首阶段领跑;B叔为挣牛排半夜整理情报
2014/07/13 DOTA
在 Django/Flask 开发服务器上使用 HTTPS
2014/07/03 Python
Python实现比较两个列表(list)范围
2015/06/12 Python
Python中的左斜杠、右斜杠(正斜杠和反斜杠)
2016/08/30 Python
Python cookbook(数据结构与算法)对切片命名清除索引的方法
2018/03/13 Python
Python实现决策树C4.5算法的示例
2018/05/30 Python
python实现输入数字的连续加减方法
2018/06/22 Python
Python3爬虫爬取百姓网列表并保存为json功能示例【基于request、lxml和json模块】
2018/12/05 Python
Python字典的基本用法实例分析【创建、增加、获取、修改、删除】
2019/03/05 Python
numpy库与pandas库axis=0,axis= 1轴的用法详解
2019/05/27 Python
Python3.6+Django2.0以上 xadmin站点的配置和使用教程图解
2019/06/04 Python
Python爬虫headers处理及网络超时问题解决方案
2020/06/19 Python
基于python图书馆管理系统设计实例详解
2020/08/05 Python
python程序实现BTC(比特币)挖矿的完整代码
2021/01/20 Python
python装饰器代码深入讲解
2021/03/01 Python
医学护理系毕业生求职信
2013/10/01 职场文书
乒乓球兴趣小组活动总结
2014/07/08 职场文书
学校元旦晚会开场白
2014/12/14 职场文书
法律进社区活动总结
2015/05/07 职场文书
辛德勒的名单观后感
2015/06/03 职场文书
股东出资协议书
2016/03/21 职场文书
2016年第十九届推普周活动总结
2016/04/06 职场文书