文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

js实现简单翻牌小游戏

2024-04-02 19:55

关注

本文实例为大家分享了js实现简单翻牌小游戏的具体代码,供大家参考,具体内容如下

1.简介

非常简单的一个网络消消乐翻牌小游戏的实现,代码量较少,不过遇到的bug和自行开发的步骤十分有纪念意义。

2.核心代码块

生成随机数列,确定图片随机分布

function getImgIndex(is){
   var index = parseInt(Math.random()*8)+1;
         if(is[index] < 2){
             is[index]++;
              } else {
             index = getImgIndex(is);
           }
        return index;
  }

通过window.onload函数定义8个背景图片随机分布

window.onload = function(){
      //规则:五个背景图,每张图出现两次,随机分配到16个div中
        var ele = document.getElementById("parent");
        var imgs = [1,2,3,4,5,6,7,8];
        var is = [0,0,0,0,0,0,0,0,0];
         for(var i = 0; i < 16; i++){
              var index = getImgIndex(is);
               console.info(index);
               ele.innerHTML += "<div id='k"+i+"' class='kid' "
                  +"οnclick='oclick(this.id,"+index+");'></div>";    
                //通过字符串拼接方式,将H5代码发送给网页执行            
          }
}

点击图片事件
oclick函数中利用f存储上个图片的index,;利用id2存储上个图片的id
再进行以下操作比较

function oclick(id,index)
            {   
                if(find[index]<2)
                {
                if(f==0){
                find[index]++;
                look(id,index);
                f=index;
                id2=id;
                }
                else
                {
                    if(f==index&&id!=id2)
                    {   
                        find[index]++;
                        look(id,index);
                        f=0;
                        id2=0;
                        marked++;
                    }
                    else
                    {   
                        find[f]=0;
                        look(id,index);
                        look(id2,f);
                        clearStyle(id);
                        clearStyle(id2);
                        f=0;
                        id2=0;
                    }
                }
                }
                if(marked==8)
                {
              alert("恭喜完成");
     }
}

图片操作函数

function look(id,index){
 var ele = document.getElementById(id);
     ele.style="background-image: url("+index+".gif);";
       }
         function clearStyle(id){
          setTimeout(function(){
            var ele = document.getElementById(id);
            ele.style="";
          }, 200);
 }

重置页面函数

function re(){
                window.location.reload();
            }

页面的设计

<body>
   <div id="parent" class="par"></div>
   <input type="button" name="b1" id="b1" value="再van♂一次" onclick="re();"/>
</body>

3.已知bug 说明(已解决)

1.点击图片本身两次导致匹配成功

解决方式:加入id判断是否为自身比较

f==index&&id!=id2

2.已匹配的图片再次点击会消除

解决方式:加入find[]数组统计图片点击次数,超过两次不再比较

if(find[index]<2)

4.全文代码

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title></title>
        <style>
        
           .kid{
               width: 100px;
               height: 100px;
               background-color: #aaffff;
               border: 1px solid black;
               margin: 10px;
               float: left;
           }
           .par{
               width: 1000px;
               padding: 10px;
               border: 1px solid black;
               float: left;
           }
        </style>
        <script>
             var f=0;
             var id2=0;
             var find = [0,0,0,0,0,0,0,0,0];
             var marked=0;
            window.onload = function(){
                //规则:五个背景图,每张图出现两次,随机分配到16个div中
                var ele = document.getElementById("parent");
                
                var imgs = [1,2,3,4,5,6,7,8];                 
                
                var is = [0,0,0,0,0,0,0,0,0];
                
                for(var i = 0; i < 16; i++){
                    var index = getImgIndex(is);
                    console.info(index);
                    ele.innerHTML += "<div id='k"+i+"' class='kid' "
                        +"οnclick='oclick(this.id,"+index+");'></div>";                
                }
            }
            function getImgIndex(is){
                var index = parseInt(Math.random()*8)+1;
                if(is[index] < 2){
                    is[index]++;
                } else {
                    index = getImgIndex(is);
                }
                return index;
            }
            function oclick(id,index)
            {   
                if(find[index]<2)
                {
                if(f==0){
                find[index]++;
                look(id,index);
                f=index;
                id2=id;
                }
                else
                {
                    if(f==index&&id!=id2)
                    {   
                        find[index]++;
                        look(id,index);
                        f=0;
                        id2=0;
                        marked++;
                    }
                    else
                    {   
                        find[f]=0;
                        look(id,index);
                        look(id2,f);
                        clearStyle(id);
                        clearStyle(id2);
                        f=0;
                        id2=0;
                    }
                }
                }
                if(marked==8)
                {
                    alert("恭喜完成");
                }
            }
            function look(id,index){
                var ele = document.getElementById(id);
                ele.style="background-image: url("+index+".gif);";
            }
            function clearStyle(id){
                setTimeout(function(){
                        var ele = document.getElementById(id);
                        ele.style="";
                    }, 200);
            }
            function re(){
                window.location.reload();
            }
        </script>
    </head>
    <body>
        <div id="parent" class="par"></div>
            <input type="button" name="b1" id="b1" value="再van♂一次" onclick="re();"/>
    </body>
</html>

注意:使用需修改图片地址url

实现效果

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

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-前端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯