纯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创建一个旋转可变色按钮
Dec 31 HTML / CSS
CSS3正方体旋转示例代码
Aug 08 HTML / CSS
非常震撼的纯CSS3人物行走动画
Feb 24 HTML / CSS
CSS3实现翘边的阴影效果的代码示例
Jun 13 HTML / CSS
HTML5中canvas中的beginPath()和closePath()的重要性
Aug 24 HTML / CSS
html5 css3实例教程 一款html5和css3实现的小机器人走路动画
Oct 20 HTML / CSS
canvas实现漂亮的下雨效果的示例
Apr 18 HTML / CSS
Canvas系列之滤镜效果
Feb 12 HTML / CSS
iframe跨域的几种常用方法
Nov 11 HTML / CSS
Html5写一个简单的俄罗斯方块小游戏
Dec 03 HTML / CSS
用canvas显示验证码的实现
Apr 10 HTML / CSS
html5跳转小程序wx-open-launch-weapp踩坑
Dec 02 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对象类型判断
2008/08/27 PHP
基于递归实现的php树形菜单代码
2014/11/19 PHP
YII Framework框架教程之安全方案详解
2016/03/14 PHP
jQuery学习4 浏览器的事件模型
2010/02/07 Javascript
Jquery实现侧边栏跟随滚动条固定(兼容IE6)
2014/04/02 Javascript
jQuery不兼容input的change事件问题解决过程
2014/12/05 Javascript
JavaScript判断字符长度、数字、Email、电话等常用判断函数分享
2015/04/01 Javascript
JS选项卡动态替换banner图片路径的方法
2015/05/11 Javascript
javascript合并表格单元格实例代码
2016/01/03 Javascript
详解iframe与frame的区别
2016/01/13 Javascript
JavaScript基本语法学习教程
2016/01/14 Javascript
JS添加删除DIV的简单实例
2016/07/08 Javascript
AngularJS ng-repeat指令中使用track by子语句解决重复数据遍历错误问题
2017/01/21 Javascript
微信小程序动态显示项目倒计时效果
2017/06/13 Javascript
微信小程序下拉刷新界面的实现
2017/09/28 Javascript
html中通过JS获取JSON数据并加载的方法
2017/11/30 Javascript
Angularjs中date过滤器失效的问题及解决方法
2018/07/06 Javascript
Vue实现美团app的影院推荐选座功能【推荐】
2018/08/29 Javascript
用vue-cli开发vue时的代理设置方法
2018/09/20 Javascript
JS实现瀑布流效果
2020/03/07 Javascript
vue+elementui实现点击table中的单元格触发事件--弹框
2020/07/18 Javascript
详解Python读取配置文件模块ConfigParser
2017/05/11 Python
Python continue继续循环用法总结
2018/06/10 Python
python2.7 安装pip的方法步骤(管用)
2019/05/05 Python
Python如何爬取微信公众号文章和评论(基于 Fiddler 抓包分析)
2019/06/28 Python
Keras官方中文文档:性能评估Metrices详解
2020/06/15 Python
pycharm 实现光标快速移动到括号外或行尾的操作
2021/02/05 Python
德国汽车零件和汽车配件网上商店:kfzteile24
2018/11/14 全球购物
Bibloo匈牙利:女装、男装、童装及鞋子和配饰
2019/04/14 全球购物
员工生日会策划方案
2014/06/14 职场文书
2014年采购部工作总结
2014/11/20 职场文书
教师个人自我评价
2015/03/04 职场文书
求职信范文怎么写
2015/03/19 职场文书
课改心得体会范文
2016/01/25 职场文书
2016年幼儿园庆六一开幕词
2016/03/04 职场文书
python库Tsmoothie模块数据平滑化异常点抓取
2022/06/10 Python