//-------全局变量-------
var data={
"10":["
data:image/s3,"s3://crabby-images/2e143/2e1439fad7c5098e4f83dde9a45854617c166089" alt=""
"],"11":["
data:image/s3,"s3://crabby-images/3f41e/3f41eee4c7b612e6ebca6131d8fac22a8b5c211e" alt=""
"],"12":["
data:image/s3,"s3://crabby-images/9604e/9604e8f633a6f1a66b06aafeb98a499d857e6c04" alt=""
"],"13":["
data:image/s3,"s3://crabby-images/0572a/0572a287725ea2712ace72875296c800eddfa796" alt=""
"],
"14":["
data:image/s3,"s3://crabby-images/28619/28619e8c16b5466db21b727b19137df7a618068d" alt=""
"],"15":["
data:image/s3,"s3://crabby-images/25ca9/25ca9868d06e508c0e907c9674ec264864a39c8b" alt=""
"],"16":["
data:image/s3,"s3://crabby-images/63773/63773d52e3b1fd167d2a08e158902df34f0fd573" alt=""
"],"17":["
data:image/s3,"s3://crabby-images/bd5af/bd5af080ad57ace523e6c0b78a218f4434961d84" alt=""
"],
"18":["
data:image/s3,"s3://crabby-images/54424/54424f1c6d192341b5d5c4f357d317d118bc67b5" alt=""
"],"19":["
data:image/s3,"s3://crabby-images/84d8f/84d8f2eae12443b58a2af5e98c1bec9b5e0cf4f3" alt=""
"],"20":["
data:image/s3,"s3://crabby-images/bd0d3/bd0d309b3555b61a69b0758e89305aa52ae95099" alt=""
"],"21":["
data:image/s3,"s3://crabby-images/a4750/a475033c72035cd23ae799427fcf6c15dc266567" alt=""
"],
"22":["
data:image/s3,"s3://crabby-images/91b01/91b01df81d8be897785d3a3dddfbaeff703ca288" alt=""
"],"23":["
data:image/s3,"s3://crabby-images/763a3/763a3ad27fc9040fd7bc643475fe9adc8b86fd52" alt=""
"],"24":["
data:image/s3,"s3://crabby-images/203c4/203c4cadcef65acdf2536e1154a04bc75173834b" alt=""
"],"25":["
data:image/s3,"s3://crabby-images/9b8b4/9b8b472ff17ca1ea3916fd53a5562c8ffa568856" alt=""
"],
"26":["
data:image/s3,"s3://crabby-images/68ae5/68ae57af7add9ffa0f7ac68745a5f7622b316a94" alt=""
"],"27":["
data:image/s3,"s3://crabby-images/37890/378907253e5fe66aec076ad73195f2d6f1340cd5" alt=""
"],"28":["
data:image/s3,"s3://crabby-images/ad398/ad398c8d4dc3337de267199332a38e1a9cdcc104" alt=""
"],"29":["
data:image/s3,"s3://crabby-images/6967b/6967bbc7f7b087ce2bd2d67b95a518a0deac175e" alt=""
"],
"30":["
data:image/s3,"s3://crabby-images/edb72/edb72bffd9ccb72b02d6df57cc6cba4f04248b34" alt=""
"],"31":["
data:image/s3,"s3://crabby-images/b9bf2/b9bf255bf8dee2d68a1e926e1fe13529a8b89ed1" alt=""
"],"32":["
data:image/s3,"s3://crabby-images/9bc12/9bc12a8fc9103e91f92ff5b6d155cfda78b4eae7" alt=""
"],"33":["
data:image/s3,"s3://crabby-images/577cf/577cfc15d204f86f9ef3481946c874bcf3a69d6a" alt=""
"],
"34":["
data:image/s3,"s3://crabby-images/7b5c2/7b5c224ffca81ced3c74bd2fe3ca40df365695f5" alt=""
"],"35":["
data:image/s3,"s3://crabby-images/bd473/bd473393a5368e07200d43b27aa58779a04ea1d2" alt=""
"]
};
var datas=new Array();//随机出现的 class样式以数组中偶数存储,图片以数组中奇数存储
var now=new Date();
var Image; //随机出现图片
var Divs;//随机出现层
var count=0;//积分系统
var key;//键盘的值
var amounts=1;//出现字母图片的个数
var gametime=30;//控制游戏的时间
var gametimes;//时间为0
var gametimess=30;//显示时钟变量
var time1;//setInterval变量
var time2=5000;//设定setInterval的时间
var time3;
var tab;//用来记录,传递tabindex焦点位置的值
//--------这样写为了兼容FF浏览器-------
var plug = {
addEvent:function(o,e,f){
if(o.addEventListener){
o.addEventListener(e,f,false);
}
else if(o.attachEvent){
o.attachEvent("on"+e,f);
}
}
}
plug.addEvent(window,"load",function(){Focus()});//兼容FF浏览器
//------1.控制游戏时间函数--------
function Gametime(){
for(gametimes=gametime;gametimes>=0;gametimes--) {
window.setTimeout('Show(' + gametimes + ')',(gametime-gametimes+2) * 1000);
}
}
function Show(gametimes){
if(gametimes==0){
clearInterval(time1);//停止游戏
alert("游戏结束!你的得分为:"+count);
$("#main").empty();//清除main中的div
$(".gameapply").empty();
$("#select1").empty();
$("#select2").empty();
count=0;//得分清空为0
Score();//让分数框显示为0
Focus();//重新生成菜单选项
}
}
//---------2.动画效果---------
function fun(){
datas.length=0;
for(var i=0;i
Image=parseInt(Math.random() * 26)+10;//随机出现字母图片
datas.push(Image);//图片以数组中偶数存储,从零开始
Divs=parseInt(Math.random() * 8)+1;//随机出现层的class样式即层的不同位置
datas.push(Divs);//样式以数组中奇数存储
var time=parseInt(Math.random() * 2000)+3000;//完成动画的时间
if(time<5000){
var $divs=$(""+data[Image]+"
");
$("#main").append($divs);
//-----JQ アニメーション関数 ----
$(".divPop" Divs)。 animate(
{"top":$(window).height() - $(".divPop" Divs).height() - $(".divPop" Divs).position().top},time, function(){$("#main").empty()})
}
}
}
//--------3. 表示する文字画像を設定します。時間 ------
function set(){
time1 = setInterval(fun,time2);
}
//----------4. --------
//--------FF ブラウザと互換性あり-----------
document.onkeydown = function keydown(e){
e = e||window.event;
var key = e.charCode||e.keyCode
select(key)
}
//--------- 5 . 判定関数 ---------
function select(key){
if(key==13){
switch(tab){
case 0:Gametime() ; Gametimeselect();time3=setInterval(countdown,1000);sets();$("#select").hide(2000);break;//ゲームを開始します
case 1:Gametime();Gametimeselect() ;time3=setInterval(countdown,1000);sets();$("#select").hide(2000);break;//ゲームを開始します
case 2:alert("ゲームのオプションはleft" );break;
case 3:window.opener=null;window.open('','_self');window.close();break;//ゲームを終了します
case 4:window .opener= null;window.open('','_self');window.close();break;//ゲームを終了
}
}
for(var j=0;j< datas.length; j=j 2){//data1 のスタイルとピクチャの値が重複しないようにするため (つまり、奇数と偶数が重複できないように)、m の値または k の値を指定します。特定の値だけ異なる必要があります)
if(key== datas[j] 55){
$(".divPop" datas[j 1]).hide();//キーの値が等しい場合、レイヤーを非表示にします
delete datas[j]; //重複する文字を避けるために、配列内で (key==datas[j] 55) が走査されるたびに、この値を次のようにする必要があります。
count =10;
break;
}
}
//--------6. -------
function Focus(){
//----- ----ゲームインターフェイスを初期化します--------
var $selects=$( "$(".gameapply").append($selects);
for( var i=30;i<=300;i=i 30){
$("#select1 ").append('')
}
for(var j=1;j$("#select2 ").append('')
}
//----------先頭の最初の入力のフォーカスを取得します-- ------
$(".inputs:first").trigger("focus").addClass ("input1");
tab=1;//最初に Enter が入力できないためフォーカスを取得するには、キーボード入力イベントを呼び出す必要があります
var tabIndex=1;
//----- -----tr 行数と入力数を取得します----- --
$("#tables").find("tr").each(function(r) {
$ (this).find("input").attr("tabindex", r 1) );//tabindex はフォーカス位置の値で、初期値は 1 に割り当てられ、トラバーサルは 1-2-3-4
}) ;
//------ -- 入力キーボードの上下操作に対する応答
$("#tables .inputs").bind("keydown", function(e){
tabIndex = parseInt($(this).attr("tabindex "));//現在の tabindex の値を取得します focus
switch(e.that){
case 38://up
tabIndex-=1;
tab=tabIndex;
break;
case 40://down
tabIndex =1;
デフォルト:
}
// --------tabIndex の値を決定します focus
if (tabIndex > 0 && tabIndex < 4) {
$(".inputs[tabindex= " tabIndex "]").focus( ).addClass("input1"); //現在の入力がフォーカスを取得します
for(var i=0;i<=4;i )
{
if( i==tabIndex){
break;
}
else{
$(this).removeClass("input1");
keydown(); >}
return true;
});
}
//---------- ---
関数 Gametimeselect (){
var option=document.getElementById("select1");
for(var i=0;iif( option[i].selected) {
gametime=option.options[i].text;
gametimess=gametime;
}
}
//---- -8. -----
function countdown(){
var timeshows=document.getElementById("timeshow");
if(timeshows){// Web ページの速度が非常に速い場合 遅い場合、タイマーの実行中はコントロールが読み込まれない可能性があります。
if(gametimessclearInterval(time3);//タイマーを停止します
}
else{
timeshows。 =ゲームタイム;
ゲームタイム--;
}
}
//----------9. 🎜>function Gameselectamount(){
var option=document.getElementById("select2");
for(var i=0;iif(option[i ] .selected) {
amounts=option.options[i].text;
}
}
}
//---------10. ---------
関数 Score(){
var sum=document.getElementById("sum");
sum.value=count; ){ //テキスト ボックスのスコアを 0 に初期化します
sum.value=count;
}
要約: 時間間隔が比較的長いため、コードがうまく最適化されていない箇所があります。つまり、文字が表示されるまでの時間間隔が長すぎます。それを修正してみることができます。コードは参照専用です
オンライン デモ:http://demo.jb51.net/js/2011/StarWars/
パッケージのダウンロード:http://www.jb51 .net /jiaoben/40902.html