基于Css3和JQuery实现打字机效果
网络编程 2021-07-04 21:48www.168986.cn编程入门
最近做项目,有需求实现一个字符逐个出现,类似于打字机效果,于是上网搜了相关资料,接下来,长沙网络推广就给大家详细介绍基于Css3和JQuery实现打字机效果,需要的朋友可以参考下
先给大家附上效果图
最近做项目的时候需要实现一个字符逐个出现的打字效果,用css的clip+css的动画实现的,与自己写的打字机效果相结合,整
理一起,效果很赞。
先来说说这个线条,我们会看到它是条,实际上就是个四周border有规律的显示隐藏,那么这里必定会想到after,before属性,
我们暂且先考虑after。
先建立一个box,然后after一个边框
<div class="box"></div> .box:before{ content: ''; position: absolute; width:px;height: px;border:px red solid; left:-px;:-px; z-index: ; }
接下来要做的就是让它有规律的显示隐藏就可以了,这里要用到clip属性,我这篇文章有讲到css圆形百分比进度条的实现原理。
在这里说说我们这个如何实现,我要让这个先显示上边框-左-底-右,这样就有了一个循环。根据clip,rect(上,右,底,
左),比如显示上边框,那么就是
clip:rect(px,px,px,px);
我们只需用animation让它依次显示就ok
@-webkit-keyframes clipMe{ %{ clip: rect(px, px, px, px); } %{ clip: rect(px, px, px, px); } %{ clip: rect(px, px, px, px); } %{ clip: rect(px, px, px, px); } %{ clip: rect(px, px, px, px); } }
然后再after中调用显示
.box:after{ -webkit-animation:clipMe s linear infinite; }
,我们再加一个一模一样的before就ok了,他们的时间间隔为s,这里要注意,如果你是延迟s,那么你会在s内看到的是整
个边框出现,这里要改为延迟-s,这个问题就会完美解决。
.box:before{ -webkit-animation:clipMe s -s linear infinite; }
//
再来说说打字机,打字机无非就是不断替换显示字符显示在屏幕上,先获取box里的内容,
<div class="box"> <span>/仅共娱乐,然并卵/</span> <p>Login : Jmingzi</p> <p>password : </p> <p>Aess is granted</p> <span>Wele ymblog. !</span> </div>
获取以后再一个个替换显示,
var t = setInterval(function(){ str = con.substr(, strlen) + "_"; me.obj.html(str); //内容打印完毕 if(strlen == con.length){ clearInterval(t); } strlen = strlen + ; }, me.speed);
在这里我只不过将它封装为一个类,便于初始化一些参数,完整代码
//初始化工作,获取几段文字内容,将它们隐藏后逐个显示即可 $(function(){ function Type(obj, speed, wele){ this.obj = obj; this.speed = speed; this.wele = wele; } Type.prototype = { init : function(){ var str = this.obj.html(); this.obj.html(this.wele); this.add(str); }, add : function(con){ var me = this; var str; var strlen = ; var t = setInterval(function(){ str = con.substr(, strlen) + "_"; me.obj.html(str); //内容打印完毕 if(strlen == con.length){ clearInterval(t); } strlen = strlen + ; }, me.speed); } } var a = new Type($('.box'), , '正在初始化...'); a.init(); });
以上就是本文的全部内容,希望对大家有所帮助
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程