原生JS会跳动的电子表
一个会跳动的电子表,源码--time.html 图片--img
github地址:https://github.com/1056237661/practiceCode
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<style type="text/css">
.timeBox{
margin: 100px;
padding: 12px;
display: inline-block;
border: 1px solid chartreuse;
}
img{
position: relative;
}
</style>
</head>
<body>
<div class="timeBox">
<img class="timeNum" src="img/1.png"/>
<img class="timeNum" src="img/2.png"/>
<img src="img/second1.png"/> <img class="timeNum" src="img/3.png"/>
<img class="timeNum" src="img/4.png"/>
<img src="img/second1.png"/> <img class="timeNum" src="img/5.png"/>
<img class="timeNum" src="img/0.png"/>
</div>
</body>
<script>
var aImg = document.getElementsByClassName("timeNum"); /* 获取显示时间的img节点 */
var shockNum = [ -15, 15, -9, 9, -4, 0]; /* 振幅的数组 */
var iNow = []; /* 存储每次需要波动的节点下标 */ /* 初始化电子表 */
time();
/* 设置定时器更新时间(1s) */
var timer = setInterval(function(){
time();
},1000);
/* 获取时间方法 */
function time(){
var dateNow = new Date(); /* new一个Date对象 */
var hours = dateNow.getHours(); /* 时 */
var minius = dateNow.getMinutes(); /* 分 */
var seconds = dateNow.getSeconds(); /* 秒 */
var str = timeStyle(hours)+timeStyle(minius)+timeStyle(seconds); /* 用字符串存储当前时间 */
/* 通过str初始化时间表 */
for (var i=0; i<str.length; i++) {
/* 判断每次是哪个需要波动 */
if (aImg[i].index != str.charAt(i)) {
/* 首次循环index值全为undefined,禁止全部波动 */
if (aImg[i].index != undefined) {
iNow.push(i); /* 把需要波动的值加入iNow数组 */
}
aImg[i].index = str.charAt(i); /* 并赋给新的值 */
aImg[i].setAttribute("src","img/"+str.charAt(i)+".png"); /* 替换数字图片 */
}
}
/* 遍历当前需要震动的数组,并设置震动定时器 */
for(x in iNow){
toshocking(iNow[x]);
}
/* 每次震动完数组清零 */
iNow.length = 0;
} /* 为每一个需要震动的数字设置震动定时器 */
function toshocking(z){
var n = 0; /* 波动次数 */
var timer2 = setInterval(function(){
aImg[z].style.top = shockNum[n]+"px";
++n;
/* 若波动完设置的振幅数组,清除定时器 */
if (n==shockNum.length) {
clearInterval(timer2)
}
},20);
} // 调整时间的样式,个位数前面加“0”
function timeStyle(num){
if (num < 10) {
return "0"+num;
}
return num+"";
}
</script>
</html>
效果:

原生JS会跳动的电子表的更多相关文章
- 用原生js写一个"多动症"的简历
用原生js写一个"多动症"的简历 预览地址源码地址 最近在知乎上看到@方应杭用vue写了一个会动的简历,觉得挺好玩的,研究一下其实现思路,决定试试用原生js来实现. 会动的简历实现 ...
- 原生JS封装Ajax插件(同域&&jsonp跨域)
抛出一个问题,其实所谓的熟悉原生JS,怎样的程度才是熟悉呢? 最近都在做原生JS熟悉的练习... 用原生Js封装了一个Ajax插件,引入一般的项目,传传数据,感觉还是可行的...简单说说思路,如有不正 ...
- 常用原生JS方法总结(兼容性写法)
经常会用到原生JS来写前端...但是原生JS的一些方法在适应各个浏览器的时候写法有的也不怎么一样的... 今天下班有点累... 就来总结一下简单的东西吧…… 备注:一下的方法都是包裹在一个EventU ...
- 原生JS实现"旋转木马"效果的图片轮播插件
一.写在最前面 最近都忙一些杂七杂八的事情,复习软考.研读经典...好像都好久没写过博客了... 我自己写过三个图片轮播,一个是简单的原生JS实现的,没有什么动画效果的,一个是结合JQuery实现的, ...
- 再谈React.js实现原生js拖拽效果
前几天写的那个拖拽,自己留下的疑问...这次在热心博友的提示下又修正了一些小小的bug,也加了拖拽的边缘检测部分...就再聊聊拖拽吧 一.不要直接操作dom元素 react中使用了虚拟dom的概念,目 ...
- React.js实现原生js拖拽效果及思考
一.起因&思路 不知不觉,已经好几天没写博客了...近来除了研究React,还做了公司官网... 一直想写一个原生js拖拽效果,又加上近来学react学得比较嗨.所以就用react来实现这个拖 ...
- 原生JS实现全屏切换以及导航栏滑动隐藏及显示——重构前
思路分析: 向后滚动鼠标滚轮,页面向下全屏切换:向前滚动滚轮,页面向上全屏切换.切换过程为动画效果. 第一屏时,导航栏固定在页面顶部,切换到第二屏时,导航条向左滑动隐藏.切换回第一屏时,导航栏向右滑动 ...
- 原生js实现autocomplete插件
在实际的项目中,能用别人写好的插件实现相关功能是最好不过,为了节约时间成本,因为有的项目比较紧急,没充分时间让你自己来写,即便写了,你还要花大量时间调试兼容性.但是出于学习的目的,你可以利用闲暇时间, ...
- 原生js封装ajax:传json,str,excel文件上传表单提交
由于项目中需要在提交ajax前设置header信息,jquery的ajax实现不了,我们自己封装几个常用的ajax方法. jQuery的ajax普通封装 var ajaxFn = function(u ...
随机推荐
- yii2实战教程之新手入门指南-简单博客管理系统
作者:白狼 出处:http://www.manks.top/document/easy_blog_manage_system.html 本文版权归作者,欢迎转载,但未经作者同意必须保留此段声明,且在文 ...
- [Bind(Exclude = "OrderId")][ScaffoldColumn(false)]
[Bind(Exclude = "OrderId")] 的意思是:View里的Model,在你提交给 Action时,不会绑定到Action的参数Model,默认它会绑定. mvc ...
- ThinkPHP实现定时任务
项目服务端框架我选用的是ThinkPHP,由于策划案中有需求要定时刷新指定数据,所以在windows平台我使用微软的计划任务调用bat脚本来执行下面的命令来完成 php index.php /Home ...
- ubuntu无限卡在logo界面
ubuntu默认的是lightdm显示管理器,GDM就是Gnome display manager,lightdm是ubuntu开发的代替gdm的显示管理器.如果ubuntu进不去图形界面,除了重新安 ...
- Ubuntu 16.04下Linux驱动编写第一步
源码环境的搭建 Install源码 >sudo apt-cache search linux-source linux-source - Linux kernel source with Ubu ...
- java基础学习02(简单的java程序)
简单的java程序 一.完成的目标 1. 理解java程序的基本组成 2. 如何对程序代码进行注释 3. java标识符的命名规则 4. 了解java中的关键字 5. 使用java定义变量或声明变量 ...
- springMVC异常&&重定向&&转发
SpringMVC核心技术---转发和重定向 当处理器对请求处理完毕后,向其他资源进行跳转时,有两种跳转方式:请求转发与重定向.而根据要跳转的资源类型,又可分为两类:跳转到页面与跳转到其他处理器.对于 ...
- 【IDEA】intellij idea 插件推荐
CSDN 2016博客之星评选结果公布 [系列直播]零基础学习微信小程序! "我的2016"主题征文活动 博客的神秘功能 [IDEA]intellij idea ...
- spring3 循环依赖
循环依赖就是循环引用,就是两个或多个Bean相互之间的持有对方,比如CircleA引用CircleB,CircleB引用CircleC,CircleC引用CircleA,则它们最终反映为一个环.此处不 ...
- codevs 1472 体检
题目描述 Description 郑厂长不是正厂长 也不是副厂长 他根本就不是厂长 只是公司的一个码农 郑厂长所在的公司每一年都要组织员工体检,比如量身高体重.测血压之类的,今年也不例外. 这次总共有 ...