简介

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

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


先展示这丑陋的界面吧

登录页

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

扫雷网页版-风君雪科技博客

注册页

扫雷网页版-风君雪科技博客

核心页

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

扫雷网页版-风君雪科技博客


主要思路 

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


访问网址: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。



程序宅男