1. 程式人生 > 程式設計 >js實現金山打字通小遊戲

js實現金山打字通小遊戲

本文例項為大家分享了js實現金山打字通小遊戲的具體程式碼,供大家參考,具體內容如下

字母勻速隨機下落,鍵盤按下對應字母按鍵,字母消失重新生成新字母,新字母可幫助回撥一部分初始高度

效果

js實現金山打字通小遊戲

1.頁面內容

列表內放字母

<ul id="box">
 <li></li>
 <li>A</li>
 </ul>

**

2.頁面樣式
**

1)清除li園標
2)確定列表位置,為字母隨機位置下降準備

*{
 padding: 0;
 margin: 0;
 }
 #box li{
 list-style: none;
 font-size: 100px;
 }
 /*確定位置便於下降*/
 #box{
 position: absolute;
 top: 0;
 left: 0;
 }

3.判斷按的按鍵

1、鍵盤按鍵按下事件

window.onkeydown=function(e){ }

2、獲得相容性物件

var ev=window.event||e;

3.獲得按下的鍵盤碼並轉換為對應按鍵

var key=String.fromCharCode(ev.keyCode);

4.遍歷獲得列表內容對比

1)迴圈li標籤

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

2)內容對比

if(list[i].innerHTML==key){  }

3)相同則刪除頁面上顯示的字母

box.removeChild(list[i]);

5.清除字母后重新生成新的隨機字母

1)在字母表中獲得隨機字母

var num=Math.floor(Math.random()*(all.length-1+1-0)+0);

2)將隨機字母加入li中

var new_list=document.createElement('li');

3)給新li進行賦值

new_list.innerHTML=all[num];

4)將新li加入ul中

box.appendChild(new_list);

6.定時字母下落

1)設定定時器

var time=setInterval(function(){ },1000)

2)方法參考浮動廣告博文

7.新字母的位置隨機生成

1)消除成功後高度向上縮一部分
2)左右利用隨機數生成

var left=Math.floor(Math.random()*(1000-1+1-0)+0);
 box.style.left=left+"px";

8.原始碼

<html>
 <head>
 <meta charset="UTF-8">
 <title></title>
 <style>
 *{
 padding: 0;
 margin: 0;
 }
 #box li{
 list-style: none;
 font-size: 100px;
 }
 /*確定位置便於下降*/
 #box{
 position: absolute;
 top: 0;
 left: 0;
 }
 </style>
 </head>
 <body>

 <ul id="box">
 <li></li>
 <li>A</li>
 </ul>
 
 <script>
 var p=document.getElementById("p");
 var new_box=document.getElementById("new_box");
 var box=document.getElementById("box");
 var all='ABCDEFGHIJQLMEOPQRSTUVWXYZ';
 window.onkeydown=function(e){
// 獲得相容性物件
 var ev=window.event||e;
// 獲得按下的按鍵並轉換為對應按鍵
 var key=String.fromCharCode(ev.keyCode);
 var list=document.getElementById("box").getElementsByTagName('li');
// 迴圈li標籤,將按鍵與標籤內容進行對比
 for(var i=0;i<list.length;i++){
// 內容對比,內容相同則刪除頁面上顯示的字母
  if(list[i].innerHTML==key){
  box.removeChild(list[i]);
  var p_old_top=box.offsetTop;
  var p_new_top=p_old_top-150;
  box.style.top=p_new_top+"px";
  var left=Math.floor(Math.random()*(1000-1+1-0)+0);
  box.style.left=left+"px";
  var num=Math.floor(Math.random()*(all.length-1+1-0)+0);
//  將隨機字母加入li中  
  var new_list=document.createElement('li');
//  給新li進行賦值
  new_list.innerHTML=all[num];
//  將新li加入ul中
  box.appendChild(new_list);
  }
 }
 
 }
 
// 定時器保證下落速度
 var time=setInterval(function(){
// 獲取ul的老位置
 var old_top=box.offsetTop;
// 計算ul的新位置
 var new_top=old_top+2;
// 將新值賦值回去
 box.style.top=new_top+"px";
 },15)
 
 </script>
 </body>
</html>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。