zoukankan      html  css  js  c++  java
  • 扫雷网页版

    简介

    嗯,由于登录注册等不是这次的重点,所以没有设计界面,丑着看吧。

    主要是感受后端与前端的交互【分离】


    先展示这丑陋的界面吧

    登录页

    [简单的登录操作,status是用来判断反馈登录是否成功的]

    注册页

    核心页

    主要需要加载的数据也就登录的用户名+面盘二维数组+当前得分+排行


    主要思路 

    1.  面盘的二维数组在上一个博文已经写了,如何获得一个带有雷和数字的完整棋盘[指这个面盘]
    2. 获得二维数组后,一开始,所有的按钮都设置成空白内容,当点击时,获得点击的按钮的编号,
      从而更改内容位面盘上该处的值,并且设置位enabled-false避免重复点刷分。
    3. 点按钮的同时判断是雷上传数据扣分,不是加分
    4. 至于排名啥的再熟悉不过了吧,不多赘述
    5. 一个核心:数组只要直接返回给用户就行,不同用户获得不同数组,由于用户已经获得自己
      获得的数组,所以彼此不会干扰到,就不会出现彼此数据混乱的情况。

    访问网址:http://www.dreamcenter.top/saolei/

    可能不会留太久(服务器太贵)


    前端源码[不包含登陆注册页了]

      1 <!DOCTYPE html>
      2 <html>
      3     <head>
      4         <meta charset="utf-8" />
      5         <script src="./js/jquery-3.4.1.js"></script>
      6         <script>
      7             $(function(){
      8                 $.post("/saolei/usermanager",{"code":"1"},function(data){
      9                     console.log(data);
     10                     if(data.code == "1"){
     11                         $(".username").text(data.username+"!");
     12                         $(".score").text(data.score);
     13                         $.post("/saolei/usermanager",{"code":"3"},function(data){
     14                             for(var i = 0;i<data.length;i++){
     15                                 //<li><b>username</b>--<span>score</span></li>
     16                                 $("#list").append("<li><b>"+data[i].name+"</b>>>><span>"+data[i].score+"</span></li>");
     17                             }
     18                         });
     19                         // $("#reset").click(function(){
     20                         //     var pw = $("#change").val();
     21                         //     $.post("/saolei/reset",{"pw":pw},function(data){
     22                         //         alert(data.tip);
     23                         //     });
     24                         // });
     25                         $("#show").click(function(){
     26                             //$.post("/saolei/reset",{"pw":"9981"});
     27                             
     28                             //扫完判断参数
     29                             var total = 90;
     30                             //开头三步计数器
     31                             var count = 3;
     32                             //错误计数
     33                             var fault = 0;
     34                             
     35                             $.post("/saolei/show",function(data){
     36                                 var num = 10;
     37                                 var value = data.show;
     38                                 //var cover = [[0,0],[0,0]];
     39                                 $("table tr").empty();
     40                                 for(var i = 0;i<num;i++){
     41                                     $("table").append("<tr></tr>");
     42                                     for(var j = 0;j < num;j++){
     43                                         //显示
     44                                         //if(cover[i][j]==0){
     45                                             $("table tr:nth-child("+(i+1)+")").append("<td><button data-place-x=""+j+"" data-place-y=""+i+"">?</button></td>");
     46                                         /*}
     47                                         else{
     48                                             $("table tr:nth-child("+(i+1)+")").append("<td><button>"+value[i][j]+"</button></td>");
     49                                         }*/
     50                                     }
     51                                 }
     52                                 
     53                                 //设置样式
     54                                 $("table td").css("width","20px");
     55                                 $("table td").css("height","20px");
     56                                 $("table td").css("padding","0");
     57                                 $("table td button").css("width","100%");
     58                                 $("table td button").css("height","100%");
     59                                 
     60                                 
     61                                 //添加事件
     62                                 $("tr td button").click(function(){
     63                                     //坐标
     64                                     var xt = $(this).attr("data-place-x");
     65                                     var yt = $(this).attr("data-place-y");
     66                                     
     67                                     //发送请求
     68                                     //console.log("("+xt+","+yt+")");
     69                                     $(this).text(value[yt][xt]);
     70                                     
     71                                     
     72                                     
     73                                     //翻面
     74                                     $(this).attr("disabled","true");
     75                                     
     76                                     //显示效果
     77                                     if(value[yt][xt]==-1){
     78                                         $(this).css("background-color","red");
     79                                         fault++;
     80                                         
     81                                         if(count>0){
     82                                             $.post("/saolei/usermanager",{"code":"2","score":"-90"},function(data){
     83                                                 $(".score").text(data.score);
     84                                                 $.post("/saolei/usermanager",{"code":"3"},function(data){
     85                                                     $("#list").empty();
     86                                                     for(var i = 0;i<data.length;i++){
     87                                                         $("#list").append("<li><b>"+data[i].name+"</b>>>><span>"+data[i].score+"</span></li>");
     88                                                     }
     89                                                 });
     90                                             });
     91                                             count--;
     92                                         }else{
     93                                             $.post("/saolei/usermanager",{"code":"2","score":"-234"},function(data){
     94                                                 $(".score").text(data.score);
     95                                                 $.post("/saolei/usermanager",{"code":"3"},function(data){
     96                                                     $("#list").empty();
     97                                                     for(var i = 0;i<data.length;i++){
     98                                                         $("#list").append("<li><b>"+data[i].name+"</b>>>><span>"+data[i].score+"</span></li>");
     99                                                     }
    100                                                 });
    101                                             });
    102                                         }
    103                                         
    104                                     }else{
    105                                         total--;
    106                                         count--;
    107                                         $(this).css("background-color","greenyellow");
    108                                         $.post("/saolei/usermanager",{"code":"2","score":"1"},function(data){
    109                                             //console.log(total);
    110                                             $(".score").text(data.score);
    111                                             
    112                                             $.post("/saolei/usermanager",{"code":"3"},function(data){
    113                                                 $("#list").empty();
    114                                                 for(var i = 0;i<data.length;i++){
    115                                                     $("#list").append("<li><b>"+data[i].name+"</b>>>><span>"+data[i].score+"</span></li>");
    116                                                 }
    117                                                 if(total==0){
    118                                                     if(fault==0){
    119                                                         $.post("/saolei/usermanager",{"code":"2","score":"100"},function(data){
    120                                                             $(".score").text(data.score);
    121                                                             $.post("/saolei/usermanager",{"code":"3"},function(data){
    122                                                                 $("#list").empty();
    123                                                                 for(var i = 0;i<data.length;i++){
    124                                                                     $("#list").append("<li><b>"+data[i].name+"</b>>>><span>"+data[i].score+"</span></li>");
    125                                                                 }
    126                                                             });
    127                                                         });
    128                                                         alert("雷已全部扫完,并且由于全对获得100积分,换张图继续吧!");
    129                                                     }else{
    130                                                         alert("雷已全部扫完,换张图吧!");
    131                                                     }
    132                                                     total=90;
    133                                                 }
    134                                             });
    135                                             //
    136                                         });
    137                                         
    138                                     }
    139                                     console.log(fault);
    140                                 });
    141                             });
    142                         });
    143                     }else{
    144                         window.location.href="login.html";
    145                     }
    146                 });
    147             });
    148         </script>
    149         <style>
    150             a{
    151                 text-decoration: none;
    152                 color: blueviolet;
    153             }
    154         </style>
    155         <title>在线扫雷</title>
    156     </head>
    157     <body>
    158         <button id="show">加载</button>
    159         <span>欢迎<span class="username" style="font-weight: bold;">游客!</span></span>
    160         <a href="https://docs.qq.com/doc/DV2p4emllcnFTbWdY" target="_blank"> 更新状况 |</a>
    161         <a href="https://docs.qq.com/doc/DV0JjSXZJQkdZR2pH" target="_blank"> 需求池 |</a>
    162         <a href="https://docs.qq.com/form/fill/DV2FQb0NBbk5jQ0hp?_w_tencentdocx_form=1" target="_blank"> 建议&反馈 </a>
    163         <!-- <input type="password" id="change" placeholder="输入正确指令重置"/>
    164         <button id="reset" >重置</button> -->
    165         <hr />
    166         <table border="1px" cellspacing="0" cellpadding="">
    167             
    168         </table>
    169         <p style="color: blue;font-size: 12px;">规则0:点左上角加载按钮获得第一张图</p>
    170         <p style="color: blue;font-size: 12px;">规则1:一张图有10个雷,一共100个格子</p>
    171         <p style="color: blue;font-size: 12px;">规则2:没踩到雷+1分,踩到雷-234分</p>
    172         <p style="color: blue;font-size: 12px;">规则3:可以再次点加载获得新图</p>
    173         <p style="color: blue;font-size: 12px;">规则4:第一个挖的可能是雷(防止刷分:不断刷新挖一个)</p>
    174         <p style="color: blue;font-size: 12px;">规则5:前三步如果踩到雷只扣90分<i style="color: red;font-size: 8px;"> NEW</i></p>
    175         <p style="color: blue;font-size: 12px;">规则6:一局全对奖励100分<i style="color: red;font-size: 8px;"> NEW</i></p>
    176         <p>您当前总得分:<span class="score">0</span></p>
    177         
    178         <div>
    179             <p>排行榜:</p>
    180             <ol id="list">
    181             </ol>
    182         </div>
    183     </body>
    184 </html>
    View Code

    至于后端返回的东西看这一个页面的源码应该都清楚了吧,不多展示,其它的都可自己动脑设计出来。

    结束,啦啦啦。

    不过最大的问题不是上面这些问题,是其平衡问题,就是扫雷加减分的平衡太难平衡了,
    一伙儿负几百一伙儿正几千QAQ。



    程序宅男
  • 相关阅读:
    js基础 ---- 为什么定时器时间不准确
    vue 3.0 ---- reactive函数
    vue 3.0 ---- ref函数
    vue 3.0 ---- setup函数
    vue 3.0 ---- 什么是vite
    Vue warn]: Error in event handler for "click": "TypeError: fns.apply is not a function"
    vueJs 自动清除文本框的 空格
    vue 报错解决 -------- DOMException: Failed to execute 'insertBefore' on 'Node' --------------------"NotFoundError: Failed to execute 'insertBefore' on 'Node': The node before
    vue 中 uuid 的使用以及作用
    赞不绝口钉钉自动点赞器
  • 原文地址:https://www.cnblogs.com/dreamcenter/p/12791364.html
Copyright © 2011-2022 走看看