动态的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 相关文章推荐
利用javascript移动div层-javascript 拖动层
Mar 22 Javascript
一些常用的JS功能函数(2009-06-04更新)
Jun 04 Javascript
JavaScript高级程序设计 扩展--关于动态原型
Nov 09 Javascript
JS选中checkbox后获取table内一行TD所有数据的方法
Jul 01 Javascript
Bootstrap每天必学之下拉菜单
Nov 25 Javascript
Node.js返回JSONP详解
May 18 Javascript
jQuery简单自定义图片轮播插件及用法示例
Nov 21 Javascript
jQuery中用on绑定事件时需注意的事项
Mar 19 Javascript
vue路由守卫+登录态管理实例分析
May 21 Javascript
vue设置动态请求地址的例子
Nov 01 Javascript
实现vuex原理的示例
Oct 21 Javascript
JS不要再到处使用绝对等于运算符了
Apr 30 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+DBM的同学录程序(5)
2006/10/09 PHP
截获网站title标签之家内容的例子
2006/10/09 PHP
PHP中用hash实现的数组
2011/07/17 PHP
简单实用的PHP防注入类实例
2014/12/05 PHP
php数据结构之顺序链表与链式线性表示例
2018/01/22 PHP
PHP实现的多维数组去重操作示例
2018/07/21 PHP
extjs 分页使用jsp传递数据示例
2014/07/29 Javascript
jquery实现类似淘宝星星评分功能实例
2014/09/12 Javascript
学习JavaScript设计模式(封装)
2015/11/26 Javascript
用window.onerror捕获并上报Js错误的方法
2016/01/27 Javascript
JavaScript中split与join函数的进阶使用技巧
2016/05/03 Javascript
jQuery插件Validation快速完成表单验证的方式
2016/07/28 Javascript
JS常用加密编码与算法实例总结
2016/12/22 Javascript
JavaScript之RegExp_动力节点Java学院整理
2017/06/29 Javascript
vue中的provide/inject的学习使用
2018/05/09 Javascript
13 个npm 快速开发技巧(推荐)
2019/07/04 Javascript
vue实现在线学生录入系统
2020/05/30 Javascript
Vue 简单实现前端权限控制的示例
2020/12/25 Vue.js
使用python获取CPU和内存信息的思路与实现(linux系统)
2014/01/03 Python
解读Python编程中的命名空间与作用域
2015/10/16 Python
解决Python3 被PHP程序调用执行返回乱码的问题
2019/02/16 Python
Pytorch之Variable的用法
2019/12/31 Python
在Pytorch中计算卷积方法的区别详解(conv2d的区别)
2020/01/03 Python
python 实现在无序数组中找到中位数方法
2020/03/03 Python
Python实现SMTP邮件发送
2020/06/16 Python
python3从网络摄像机解析mjpeg http流的示例
2020/11/13 Python
使用OpenCV校准鱼眼镜头的方法
2020/11/26 Python
CSS3 rgb and rgba(透明色)的使用详解
2020/09/25 HTML / CSS
毕业生求职找工作的自我评价范文
2013/11/27 职场文书
市场开发计划书
2014/05/07 职场文书
财务管理专业毕业生求职信
2014/06/02 职场文书
学校个人对照检查材料
2014/08/26 职场文书
“四风”问题对照检查材料思想汇报
2014/09/16 职场文书
个人工作失误的保证书怎么写?
2019/06/21 职场文书
通过T-SQL语句创建游标与实现数据库加解密功能
2022/03/16 SQL Server
Java实现扫雷游戏详细代码讲解
2022/05/25 Java/Android