本文实例为大家分享了javascript实现秒表计时游戏的具体代码,供大家参考,具体内容如下

一、说明

本游戏页面设计分为左右两栏。左上为跑马灯,左下为计时器和”START”按钮;右上为排行榜,右下为游戏规则说明。

跑马灯用的是定时器,循环走一遍。计时器是从”00:00:000”开始计时,需要点击”START”按钮开始游戏,停止游戏是点击空格键。游戏计算的是停止时间时刻和”00:10:000”时刻,也就是和10秒整的时间差。注意如果是在10秒前按下空格键停止,是有惩罚的,惩罚为之前计算的时间差翻倍。最后是按最终时间差从小到大顺序进行排名。

二、效果展示

三、代码

3.1 HTML

计时小游戏

00:

00:

000

START

排行榜
排名 玩家ID 时间记录 是否罚时 时间差
计时游戏规则:

  点击"START"开始游戏,当秒表计时到10秒的时候,请按下键盘的空格键,系统将记录按下键盘时刻秒表与10秒时刻的时间差,并按照最终时间差从小到大顺序进行排名。

如果想要重新开始游戏,只需再次点击"START"。

注意:如果在秒表10秒前按下空格键,属于“抢跑”违规,需要罚时,最终时间差翻倍!

3.2 CSS

body {

background-image: url("../images/img02.png");

background-size: cover;

}

body>div {

display: flex;

margin: 50px 50px 0px 50px;

}

/* 分栏-左部 */

#left {

height: 550px;

flex: 1;

text-align: center;

background-color: rgba(10, 0, 6, 0.3);

}

/* 跑马灯 */

#marquee {

width: 100%;

height: 300px;

}

#marquee table {

width: 95%;

height: 280px;

margin: 5px 20px 0px 20px;

border-spacing: 20px;

}

#marquee table td {

background-color: rgba(9, 28, 38, 0.8);

border-radius: 5px;

}

/* 计时器:分、秒、毫秒 */

#time {

font-size: 4.5em;

color: #02C4F2;

}

/* "START"按钮 */

#start {

font-size: 3em;

background-color: rgba(10, 0, 6, 0.5);

border-style: solid;

border-color: #344665;

color: #02C4F2;

border-radius: 10px;

cursor: pointer;

}

/* 分栏-右部 */

#right {

flex: 1;

margin-left: 50px;

}

/* 排行榜滚动界面 */

#right .board1 {

height: 350px;

width: 100%;

border: 1px solid #344665;

overflow-y: scroll;

padding: 5px;

background-color: rgba(10, 0, 6, 0.2);

}

/*滚动条整体样式*/

#right>div::-webkit-scrollbar {

background-color: rgba(219, 200, 212, 0.4);

}

/*滚动条里面小方块*/

#right>div::-webkit-scrollbar-thumb {

border-radius: 5px;

background: rgba(155, 24, 24, 0.5);

}

/* 排行榜 */

#leaderboard {

width: 100%;

border-color: #344665;

color: white;

font-size: 1.3em;

text-align: center;

}

#leaderboard th {

width: 18%;

}

/* 游戏规则说明 */

#right .board2 {

height: 165px;

width: 100%;

border: 1px solid #344665;

margin-top: 10px;

padding: 5px;

background-color: rgba(10, 0, 6, 0.2);

color: white;

line-height: 1.5em;

}

.board2>div {

margin: 4px;

}

3.3 Javascript

window.onload = function () {

var count = 0; // 记录开始后当前的毫秒数

var timer; // 定时器返回值,用于停止定时器

var timer_color; // 定时器返回值,用于停止跑马灯

var flag = false; // 增加判断,防止重复点击开始导致有多个定时器同时计数

/* 计时 */

var id_M = document.getElementById("id_M");

var id_S = document.getElementById("id_S");

var id_MS = document.getElementById("id_MS");

/* 跑马灯 */

var td1 = this.document.getElementById("tr1").getElementsByTagName("td");

var td2 = this.document.getElementById("tr2").getElementsByTagName("td");

var td3 = this.document.getElementById("tr3").getElementsByTagName("td");

var td4 = this.document.getElementById("tr4").getElementsByTagName("td");

var color = td1[1].style.backgroundColor; // 存储跑马灯原来的颜色,用于还原

/* 开始按钮 */

var start = this.document.getElementById("start");

start.onclick = function () {

start.blur(); // 移除焦点

if (flag) {

clearInterval(timer); // 处理没按空格键停止就再次点击"START"的情况

}

flag = true;

/* 计时器 */

var ms = new Date().getTime();

timer = setInterval(function () {

count = new Date().getTime() - ms;

id_M.innerText = handleTime1(parseInt(count / 1000 / 60));

id_S.innerText = handleTime1(parseInt(count / 1000 % 60));

id_MS.innerText = handleTime2(count % 1000);

}, 103);

/* 跑马灯 */

clear(0); // 先全部清除

row = 4; // 初始化行

col = 4; // 初始化列

timer_color = setInterval(paomadeng, 200);

}

/* 处理时间(分、秒) */

function handleTime1(num) {

if (num < 10) {

return '0' + num;

}

return num;

}

/* 处理时间(毫秒) */

function handleTime2(num) {

if (num < 10) {

return "00" + num;

} else if (num < 100) {

return '0' + num;

}

return num;

}

/* 跑马灯 */

var row = 4,

col = 4;

function paomadeng() {

if (col == -1) {

clear(col + 1);

col = 4;

}

if (row == 4) {

clear(col + 1);

td4[col].style.backgroundColor = "green";

row--;

} else if (row == 3) {

td3[col].style.backgroundColor = "red";

row--;

} else if (row == 2) {

td2[col].style.backgroundColor = "blue";

row--;

} else if (row == 1) {

td1[col].style.backgroundColor = "#47DE00";

row = 4;

col--;

}

}

/* 清除跑马灯 */

function clear(n) {

for (; n <= 4; n++) {

td1[n].style.backgroundColor = color;

td2[n].style.backgroundColor = color;

td3[n].style.backgroundColor = color;

td4[n].style.backgroundColor = color;

}

}

/* 点击空格键停止 */

this.document.onkeypress = function (ev) {

// 32对应空格

if (ev.keyCode == 32 && flag) {

clearInterval(timer);

clearInterval(timer_color);

flag = false;

// 表格添加行

addRow();

}

}

// 排行榜

var table = this.document.getElementById("leaderboard");

// 玩家最终时间差记录

var players = [];

/* 表格添加行 */

function addRow() {

var rows = table.rows.length;

var insertTr;

var before_time_diff = count - 10 * 1000; // 基础时间差

var after_time_diff; // 最终时间差

if (before_time_diff < 0) {

after_time_diff = Math.abs(before_time_diff) * 2;

} else {

after_time_diff = before_time_diff;

}

// rows==1,说明是第一个玩家;否则遍历全部玩家

if (rows != 1) {

for (var i = 0; i < players.length; i++) {

if (after_time_diff < players[i]) {

console.log(after_time_diff, players[i])

insertTr = table.insertRow(i + 1);

break;

}

}

if (insertTr == null) {

insertTr = table.insertRow(rows);

}

} else {

insertTr = table.insertRow(rows);

}

// 排名

var inserTd = insertTr.insertCell(0);

inserTd.innerText = rows

// 玩家名

var inserTd = insertTr.insertCell(1);

inserTd.innerText = "玩家" + rows

// 时间记录

var inserTd = insertTr.insertCell(2);

inserTd.innerText = id_M.innerText + ":" + id_S.innerText + ":" + id_MS.innerText

// 是否罚时

var inserTd = insertTr.insertCell(3);

if (before_time_diff < 0) {

inserTd.innerText = "是"

} else {

inserTd.innerText = "否"

}

// 最终时间差

var inserTd = insertTr.insertCell(4);

var M = handleTime1(parseInt(after_time_diff / 1000 / 60));

var S = handleTime1(parseInt(parseInt(after_time_diff / 1000 % 60)));

var MS = handleTime2(parseInt(parseInt(after_time_diff % 1000)));

inserTd.innerText = M + ":" + S + ":" + MS

// 将玩家最终时间差信息加入数组players,并排序

players.push(after_time_diff);

players.sort(sortNum); // 注意,sort是对数组中的字符串进行排序,如果是数字需要自定义

// 重置排名

resetRank();

}

/* 数组中数字的排序(从小到大) */

function sortNum(a, b) {

return a - b;

}

/* 重置排名 */

function resetRank() {

var tr = document.getElementById("leaderboard").getElementsByTagName("tr");

for (var i = 1; i < tr.length; i++) {

tr[i].getElementsByTagName("td")[0].innerText = String(i);

}

}

}

更多有趣的经典小游戏实现专题,分享给大家:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

python秒表游戏代码_Javascript实现秒表计时游戏相关推荐

  1. python打地鼠游戏代码_Python 0基础开发游戏:打地鼠(详细教程)VS code版本

    如果你没有任何编程经验,而且想尝试一下学习编程开发,这个系列教程一定适合你,它将带你学习最基本的Python语法,并让你掌握小游戏的开发技巧.你所需要的,就是付出一些时间和耐心来尝试这些代码和操作.文 ...

  2. python猜单词游戏代码_Python之猜单词游戏

    最近上完python课,老师让用python中的字典写一个猜单词游戏,于是就自己写了一个代码,可用于自己背单词,如果觉得我写的单词太简单,可以改成自己想要背诵的单词. 代码可能存在瑕疵,还请大佬指教! ...

  3. python迷宫小游戏代码_6.1 | 童年的游戏,Python一行代码就能玩

    作者 | 刘早起来源 | 早起Python 大家好,儿童节就要来了,虽然秃头程序员没有头发,但是童心还是一直都在的,今天就分享一个私藏的GitHub项目--free-python-games,一行代码 ...

  4. python拍七游戏代码_拍七数字游戏 - Johannes-Jensen - 博客园

    最近写作业时,老师留了一道关于拍七数字游戏的题,"拍7游戏"规则是:一堆人围成一圈,开始时,任意指定一人说出数字"1"后,一圈人按顺时针方向,每人按整数由小到大 ...

  5. python敲七游戏代码_酒桌上的游戏

    <酒桌上的游戏>简介: 1 .十五二十:其实也就是猜拳,只是把我们平常用一只手换成了两只手,从古到今非常流 行.游戏规则十分简单 <酒桌上的游戏>正文开始 >> 1 ...

  6. c#推箱子小游戏代码_推箱子小游戏V1.0制作

    小游戏实践 推箱子简易版 大家好,我是努力学习争取成为优秀的Game Producer的路人猿,今天来一起做一个推箱子的简易版本V1.0!下面跟我一起做吧~ 我们用到的软件如下: 编辑类 Visual ...

  7. java猜拳游戏代码_Java实现简单猜拳游戏

    本文实例为大家分享了java实现简单猜拳游戏的具体代码,供大家参考,具体内容如下 看网上的猜拳游戏那么多,但都是用switch输入数字,所以用if嵌套,写一个简单的猜拳游戏 package game; ...

  8. html5猜数字游戏代码,js猜数字小游戏的简单实现代码

    复制代码 代码如下: 简易计算机 //获取随机数 function GetRandomNum(Min,Max) { var Range = Max - Min; var Rand = Math.ran ...

  9. c语言游戏代码(c语言制作小游戏)

    用C语言编写的小游戏代码是什么? /*也不知道你是什么级别的,我是一个新手,刚接触编程语言,以下是我自己变得一个小程序,在所有c语言的编译器(vc++6.0.turbo----)上都能运行,你还可以进 ...

最新文章

  1. 【Qt】调用Python函数:无参数、单个参数、多个参数、数组参数
  2. 浏览器刷新再次升级!不同浏览器窗口
  3. 可视化LassoCV的系数图
  4. cordova + vue cli构建跨平台应用
  5. 浅析:seo工程师擅长的网站数据分析
  6. python中string的操作函数
  7. java判断一个数是不是质数(素数)
  8. 阿里云VGN5i虚拟化GPU服务器价格更低的GPU计算服务
  9. 龙芯2k按键中断驱动_外部中断按键驱动
  10. 润乾报表列太多导致渲染速度慢_报表自动化: 如何选择可视化大屏开发利器
  11. string match
  12. Mysql数据库正则表达式
  13. mysql 自定义函数 事务_MySQL存储过程、触发器、自定义函数、事务
  14. OLAP-ClickHouse-大数据Week13-DAY3-ClickHouse
  15. 梦想易语言零基础注册机到多线程教程
  16. oracle怎么看今天星期几,oracle 判断今天是星期几
  17. 后端日志【11】:回归自我,负重前行
  18. IDEA 设置4个空格代替tab
  19. 神奇的物理学(六)量子电动力学的应用
  20. 电赛A题无线运动传感节点总结(一)

热门文章

  1. jenkins ---持续集成/持续发布
  2. 多线程之interrupt
  3. Android 连接USB默认选中MTP模式
  4. 什么是对象、什么是面对对象?
  5. 世界各国 省市县 省份 城市 三级数据库表 mysql
  6. MTCNN开源训练(PNet训练)
  7. sql语言学习——数据定义语言
  8. 更新Qt Creator版本后打开之前的项目,只有.Pro的问题.
  9. 如何在Windows 10中使用“Netsh Winsock Reset”?
  10. Java在c盘fld目录下的文件名_VBS脚本常用代码大全2011整理.docx