基于Css3和JQuery实现打字机效果


Posted in Javascript onAugust 11, 2015

先给大家附上效果图:

基于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;top:-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>Access is granted</p>
<span>Welcome ymblog.net !</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, welcome){
this.obj = obj;
this.speed = speed;
this.welcome = welcome;
}
Type.prototype = {
init : function(){
var str = this.obj.html();
this.obj.html(this.welcome);
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();
});

以上就是本文的全部内容,希望对大家有所帮助

Javascript 相关文章推荐
ext jquery 简单比较
Apr 07 Javascript
jQuery调用WebService的实现代码
Jun 19 Javascript
原生js实现改变随意改变div属性style的名称和值的结果
Sep 26 Javascript
jQuery+css实现百度百科的页面导航效果
Dec 16 Javascript
jQuery及JS实现循环中暂停的方法
Feb 02 Javascript
jquery显示loading图片直到网页加载完成的方法
Jun 25 Javascript
jQuery实现简单的列表式导航菜单效果代码
Aug 31 Javascript
JavaScript快速切换繁体中文和简体中文的方法及网站支持简繁体切换的绝招
Mar 07 Javascript
window.close(); 关闭浏览器窗口js代码的总结介绍
Jul 14 Javascript
jQuery+ajax实现动态添加表格tr td功能示例
Apr 23 jQuery
es6数值的扩展方法
Mar 11 Javascript
Node.js系列之连接DB的方法(3)
Aug 30 Javascript
js实现获取当前时间是本月第几周的方法
Aug 11 #Javascript
js判断子窗体是否关闭的方法
Aug 11 #Javascript
JavaScript实现下拉列表框数据增加、删除、上下排序的方法
Aug 11 #Javascript
iframe跨域通信封装详解
Aug 11 #Javascript
javascript实现选中复选框后相关输入框变灰不可用的方法
Aug 11 #Javascript
JS+CSS实现美化的下拉列表框效果
Aug 11 #Javascript
localResizeIMG先压缩后使用ajax无刷新上传(移动端)
Aug 11 #Javascript
You might like
WINXP下apache+php4+mysql
2006/11/25 PHP
php实现jQuery扩展函数
2009/10/30 PHP
php读取目录所有文件信息dir示例
2014/03/18 PHP
CentOS 6.3下安装PHP xcache扩展模块笔记
2014/09/10 PHP
PHP验证码生成原理和实现
2016/01/24 PHP
php 输入输出流详解及示例代码
2016/08/25 PHP
PHP编写daemon process 实例详解
2016/11/13 PHP
实现laravel 插入操作日志到数据库的方法
2019/10/11 PHP
MooTools 1.2介绍
2009/09/14 Javascript
Javascript/Jquery——简单定时器的多种实现方法
2013/07/03 Javascript
js面向对象编程之如何实现方法重载
2014/07/02 Javascript
node.js中的fs.write方法使用说明
2014/12/15 Javascript
Bootstrap学习笔记 轮播(Carousel)插件
2017/03/21 Javascript
Vue form 表单提交+ajax异步请求+分页效果
2017/04/22 Javascript
bootstrap table实现x-editable的行单元格编辑及解决数据Empty和支持多样式问题
2017/08/10 Javascript
vue与bootstrap实现时间选择器的示例代码
2017/08/26 Javascript
Nodejs进阶之服务端字符编解码和乱码处理
2017/09/04 NodeJs
微信小程序 上传头像的实例详解
2017/10/27 Javascript
深入浅析Vue.js 中的 v-for 列表渲染指令
2018/11/19 Javascript
vue全局使用axios的方法实例详解
2018/11/22 Javascript
[16:56]教你分分钟做大人:司夜刺客
2014/10/30 DOTA
详解Python的Django框架中的模版继承
2015/07/16 Python
Python探索之pLSA实现代码
2017/10/25 Python
python实现Excel文件转换为TXT文件
2019/04/28 Python
Python新手如何进行闭包时绑定变量操作
2020/05/29 Python
Python bisect模块原理及常见实例
2020/06/17 Python
亚洲颇具影响力的男性在线购物零售商:His
2019/11/24 全球购物
如何实现一个自定义类的序列化
2012/05/22 面试题
介绍一下Make? 为什么使用make
2013/12/08 面试题
运输服务质量承诺书
2014/03/27 职场文书
项目合作意向书范本
2014/04/01 职场文书
企业党员一句话承诺
2014/05/30 职场文书
2016春节放假通知范文
2015/08/18 职场文书
Nginx快速入门教程
2021/03/31 Servers
基于Python实现将列表数据生成折线图
2022/03/23 Python
Win11 22H2 2022怎么更新? 获得Win1122H22022版本升级技巧
2022/09/23 数码科技