动态的9*9乘法表效果的实现代码


Posted in Javascript onMay 16, 2016

近日在群里看到有个题目,拿出来写写,

要求:

用html,css,原生js实现如图的效果,先正向输出,然后逆向回溯,最后停留在完整的画面。

动态的9*9乘法表效果的实现代码

首先:

HTML部分代码:

 <div id="result"></div> 

就是这么简单一行搞定。

CSS代码:

#result{
 width:550px;
 margin:30px auto;
 font-size:0;
 font-family:Consolas,"Liberation Mono",Menlo,Courier,monospace;
}
#result span{
 display:inline-block;
 width:60px;
 height:25px;
 line-height:25px;
 font-size:12px;
 text-align:center;
 border:1px solid #eee;
 margin: -1px 0 0 -1px;
}

CSS代码也很简单,span中的margin主要就是为了消除出现双border的问题。

接下来重点来了

javascript代码:

首先创建一个9*9乘法表的函数

function create(){
 var html = [];
 for(var i = 1;i <= 9;i++){
  for(var j = 1;j <= i;j++){
    html.push('<span>'+j+'*'+i+'='+(j*i)+'</span>');
  }
   html.push('<br/>');
 }
 return html;
}

1,新建一个用来放html代码片段的空数组:

var html = [];

2,使用for循环遍历出9*9乘法表格:

for(var i = 1;i <= 9;i++){
 for(var j = 1;j <= i;j++){
 //内容
 } 
}

3,将循环内容push进之前新建的空数组:

html.push('<span>'+j+'*'+i+'='+(j*i)+'</span>');

4,注意为了实现阶梯在j循环完毕之后添加一个换行字符:

html.push('<br/>');

5,最后记得return出刚刚那个数组:

return html;

创建9*9乘法表的函数就完成了。

接下来是将展示到页面中:

function inHTML(){
   var html = create(),
    i = 0,
    tmp = create(),
    timer = null,
    result = document.getElementById('result');
   timer = setInterval(function(){
    if(i > html.length){
     html.splice(html.length-1,1)
     result.innerHTML = html.join('');
    }
    else{
     result.innerHTML += html[i++];
    }
    if(!html.length){
     result.innerHTML = tmp.join('');
     clearInterval(timer);
    }
   },100)
  }

我们依然是创建一个新的函数:inHTML()

1,首先声明一些初始化变量

var html = create(),//调用之前创建的9*9函数
  i = 0,//初始化变量i
  tmp = create(),
  timer = null,//初始化
  result = document.getElementById('result');//获取id

2,接着我们创建一个定时器,让数据依次展示:

timer = setInterval(function(){
 //内容 
},100)

让100毫秒执行一次这个定时器

3,接着写定时器中的内容:

if(i > html.length){ //判断i是否大于html.length,如果大于就逆向展示
 html.splice(html.length-1,1)
 result.innerHTML = html.join('');
}
else{ //如果小于就正向展示
 result.innerHTML += html[i++];
}
if(!html.length){ //判断如果html.length为false时展示。
 result.innerHTML = tmp.join('');
 clearInterval(timer);//清除定时器
}

inHTML()函数也写完了,那就剩下调用了

inHTML();

完成。

大家可以去自己去试试,有更好的想法可以给我留言。

以上这篇动态的9*9乘法表效果的实现代码就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
学习YUI.Ext 第四天--对话框Dialog的使用
Mar 10 Javascript
JavaScript 获取事件对象的注意点
Jul 29 Javascript
jquery easyui combobox模糊过滤(示例代码)
Nov 30 Javascript
JavaScript数组函数unshift、shift、pop、push使用实例
Aug 27 Javascript
jQuery中:image选择器用法实例
Jan 03 Javascript
js密码强度实时检测代码
Mar 02 Javascript
JQuery控制图片由中心点逐渐放大效果
Jun 26 Javascript
表格展示利器 Bootstrap Table实例代码
Sep 06 Javascript
JavaScript数据结构与算法之二叉树添加/删除节点操作示例
Mar 01 Javascript
详解VSCode配置启动Vue项目
May 14 Javascript
微信小程序JS加载esmap地图的实例详解
Sep 04 Javascript
微信小程序3D轮播实现代码
Sep 19 Javascript
Svg.js实例教程及使用手册详解(一)
May 16 #Javascript
限制只能输入数字的实现代码
May 16 #Javascript
JavaScript开发Chrome浏览器扩展程序UI的教程
May 16 #Javascript
基于javascript实现最简单的选项卡切换效果
May 16 #Javascript
JavaScript实现页面跳转的方式汇总
May 16 #Javascript
js实现页面跳转的几种方法小结
May 16 #Javascript
WebApi+Bootstrap+KnockoutJs打造单页面程序
May 16 #Javascript
You might like
让PHP更快的提供文件下载的代码
2012/06/13 PHP
PHP中trim()函数简单使用指南
2015/04/16 PHP
PHP查找数值数组中不重复最大和最小的10个数的方法
2015/04/20 PHP
php使用file函数、fseek函数读取大文件效率对比分析
2016/11/04 PHP
PHP中的输出echo、print、printf、sprintf、print_r和var_dump的示例代码
2020/12/01 PHP
TP5多入口设置实例讲解
2020/12/15 PHP
基于jquery的跟随屏幕滚动代码
2012/07/24 Javascript
Jquery:ajax实现翻页无刷新功能代码
2013/08/05 Javascript
js给onclick赋值传参数的两种方法
2013/11/25 Javascript
js 动态加载事件的几种方法总结
2013/12/25 Javascript
JS实现很酷的水波文字特效实例
2015/02/26 Javascript
Google Maps基础及实例解析
2016/08/06 Javascript
学习Javascript闭包(Closure)知识
2016/08/07 Javascript
js实现select选择框效果及美化
2016/08/19 Javascript
Vuejs第七篇之Vuejs过渡动画案例全面解析
2016/09/05 Javascript
jquery实现提示语淡入效果
2017/05/05 jQuery
详解用vue编写弹出框组件
2017/07/04 Javascript
vue slots 组件的组合/分发实例
2018/09/06 Javascript
vue.js中ref和$refs的使用及示例讲解
2019/08/14 Javascript
小程序实现图片预览裁剪插件
2019/11/22 Javascript
Python 执行字符串表达式函数(eval exec execfile)
2014/08/11 Python
python爬虫之百度API调用方法
2017/06/11 Python
python实现redis三种cas事务操作
2017/12/19 Python
关于Pycharm无法debug问题的总结
2019/01/19 Python
Python使用scipy模块实现一维卷积运算示例
2019/09/05 Python
使用python的pyplot绘制函数实例
2020/02/13 Python
python创建文本文件的简单方法
2020/08/30 Python
Html5 webRTC简单实现视频调用的示例代码
2020/09/23 HTML / CSS
非洲NO.1网上商店:Jumia肯尼亚
2016/08/18 全球购物
如何写一份好的自荐信
2014/01/02 职场文书
弘扬职业精神演讲稿
2014/03/20 职场文书
社会治安综合治理责任书
2015/01/29 职场文书
安全员岗位职责
2015/02/10 职场文书
重阳节座谈会主持词
2015/07/03 职场文书
社区志愿服务活动感想
2015/08/07 职场文书
Redis持久化与主从复制的实践
2021/04/27 Redis