javascript實(shí)現(xiàn)簡(jiǎn)單打字游戲
本文實(shí)例為大家分享了javascript打字游戲的具體代碼,供大家參考,具體內(nèi)容如下
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>傳智打字游戲</title>
<style type="text/css">
.label{
position:absolute;left: 0px;
}
</style>
<script type="text/javascript" src="game.js"></script>
</head>
<body>
<div id="msg"></div>
<input id="startBtn" type="button" value="開(kāi)始游戲" οnclick="startGame(this)"/>
<input type="button" value="停止游戲" οnclick="stopGame()"/>
</body>
</html>
var CODE = "QWERTYUIOPASDFGHJKLZXCVBNM";
var codeArray = [];
var number = 0;
//創(chuàng)建隨機(jī)字母
function createCode(){
//0-25
var index = parseInt(Math.random()*26);
return CODE.charAt(index);
};
//創(chuàng)建顯示label方法
function createLabel(code){
/**
* <label class="label">
A
</label>
*/
var label = document.createElement("label");
label.className = "label";
label.style.top = "50px";
label.innerHTML = code;
label.code = code;
var html = document.documentElement;
//所有l(wèi)abel標(biāo)簽的x坐標(biāo)
var labelX = parseInt(Math.random()*html.clientWidth);
if(labelX>100){
labelX-=20;
}
label.style.left = labelX+"px";
return label;
}
window.onload = function(){
document.getElementById("startBtn").disabled = false;
//注冊(cè)鍵盤(pán)事件
document.documentElement.οnkeydοwn=function(event){
var keyCode = event.keyCode; //獲取按下的嗎
var code = String.fromCharCode(keyCode);//A-Z
for ( var i = 0; i < codeArray.length; i++) {
//label標(biāo)簽
var label = codeArray[i];
if(label.code==code){
clearInterval(label.interval_id);
label.parentNode.removeChild(label);
codeArray.splice(i,1);
number+=10;
document.getElementById("msg").innerHTML = number+"分";
break;
}
}
};
};
//讓label標(biāo)簽慢慢的從上向下移動(dòng)
function runLabelTop(label){
//獲取頁(yè)面的高度
var height = Math.max(document.documentElement.clientHeight,document.documentElement.scrollHeight);
label.interval_id = setInterval(function(){
//50px
var top = parseInt(label.style.top);
top+=1;
//判斷l(xiāng)abel是否已經(jīng)超過(guò)頁(yè)面的高度
if(top>height-30){
removeLabel(label,false);
}else{
label.style.top = top+"px";
}
},10);
}
//flag = false用戶(hù)沒(méi)有按下該字母
function removeLabel(label,flag){
clearInterval(label.interval_id);
label.parentNode.removeChild(label);
codeArray.shift();
number-=20;
document.getElementById("msg").innerHTML = number+"分";
}
var game_id = null;
//開(kāi)始游戲
function startGame(startButton){
startButton.disabled = true;
game_id = setInterval(function(){
//創(chuàng)建要顯示的字符
var code =createCode();
//創(chuàng)建一個(gè)label顯示字符
var label = createLabel(code);
//讓label標(biāo)簽慢慢向下移動(dòng),修改標(biāo)簽的style.top屬性
runLabelTop(label);
//把label標(biāo)簽節(jié)加入到頁(yè)面中
document.body.appendChild(label);
codeArray.push(label);
},1000);
}
//停止游戲
function stopGame(){
clearInterval(game_id);
for ( var i = 0; i < codeArray.length; i++) {
clearInterval(codeArray[i].interval_id);
codeArray[i].parentNode.removeChild(codeArray[i]);
}
codeArray = [];
document.getElementById("startBtn").disabled = false;
}
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
微信小程序和H5頁(yè)面間相互跳轉(zhuǎn)代碼實(shí)例
這篇文章主要介紹了微信小程序和H5頁(yè)面間相互跳轉(zhuǎn)代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-09-09
Prototype 1.5.0_rc1 及 Prototype 1.5.0 Pre0小抄本
Prototype 1.5.0_rc1 及 Prototype 1.5.0 Pre0小抄本...2006-09-09
javascript實(shí)現(xiàn)一款好看的秒表計(jì)時(shí)器
這篇文章主要為大家詳細(xì)介紹了一款好看的秒表計(jì)時(shí)器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-09-09
JS一維數(shù)組轉(zhuǎn)多維數(shù)組樹(shù)的方法
這篇文章主要介紹了JS一維數(shù)組轉(zhuǎn)多維數(shù)組樹(shù)的方法,文章通過(guò)代碼示例給大家講解的非常詳細(xì),?對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2024-06-06
JavaScript中的isXX系列是否繼續(xù)使用的分析
我們很容易被漂亮的代碼吸引,也不知不覺(jué)的在自己的代碼庫(kù)中加入這些。卻沒(méi)有冷靜的想過(guò)它們的優(yōu)劣。這不,我就收集了一系列形如 “是否為……?” 的判斷的boolean函數(shù)。2011-04-04
前端精度丟失問(wèn)題解決之后端Long類(lèi)型到前端的處理策略
這篇文章主要介紹了前端精度丟失問(wèn)題解決之后端Long類(lèi)型到前端的處理策略,在Web開(kāi)發(fā)中前后端數(shù)據(jù)類(lèi)型不匹配尤其是Long類(lèi)型數(shù)據(jù)到前端可能導(dǎo)致精度丟失,文章探討了此問(wèn)題并提供三種解決方法,需要的朋友可以參考下2024-09-09
js點(diǎn)擊button按鈕跳轉(zhuǎn)到另一個(gè)新頁(yè)面
點(diǎn)擊按鈕怎么跳轉(zhuǎn)到另外一個(gè)頁(yè)面呢?點(diǎn)擊圖片要跳轉(zhuǎn)到新的頁(yè)面時(shí),怎么做到呢?可以使用onclick=window.location=新頁(yè)面來(lái)實(shí)現(xiàn)2014-10-10

