簡易版九宮格相加數值相等

来源:http://www.cnblogs.com/web-cxn/archive/2016/02/23/5211535.html
-Advertisement-
Play Games

九宮格的樣子以及游戲想大家接觸過,想當年也是玩了好多九宮格游戲,其中最經典的就是1-9這九個數字填進格子,橫豎向、對角相加數值相等這個益智游戲了。今天,在一個qq群里有人問九宮格做法,我就突然想起乾前端這麼長時間還真的沒做過九宮格。今天就把我做好的實例發上來,共看客們批評教育。


九宮格的樣子以及游戲想大家接觸過,想當年也是玩了好多九宮格游戲,其中最經典的就是1-9這九個數字填進格子,橫豎向、對角相加數值相等這個益智游戲了。今天,在一個qq群里有人問九宮格做法,我就突然想起乾前端這麼長時間還真的沒做過九宮格。今天就把我做好的實例發上來,供看客們批評教育。當然這也是我的處女帖,好激動!

源碼下載:http://files.cnblogs.com/files/web-cxn/%E4%B9%9D%E5%AE%AB%E6%A0%BC%E6%BA%90%E7%A0%81.rar

實現思路:

1、每個格子輸入的數值必須為數字;

2、輸入數值不能重覆;

3、輸入數值不能小於1或大於9;

4、數值不能為空;

5、相加方式共8個,分別為橫向三個、縱向三個、兩條對角線兩個值。詳情如下:

    

       以每個格子所標記序號為標識:

      橫向三個值:0-2,3-4,6-8;

      縱向三個值:[0,3,6]、[1,4,7]、[2,5,8];

      對角線兩個值:[0,4,8]、[2,4,6]

 

 

 

 

實現過程:

很簡單,和上面圖片一樣,點擊提交按鈕開始判斷。

1、佈局

html部分:

 1 <div class="box">
 2     <input type="text">
 3     <input type="text">
 4     <input type="text">
 5     <input type="text">
 6     <input type="text">
 7     <input type="text">
 8     <input type="text">
 9     <input type="text">
10     <input type="text">
11     <button>提交</button>
12 </div>

css部分:通過css3中屬性實現。

 1 *{margin:0;padding:0;outline: none;}
 2 html,body{
 3     height: 100%;
 4     display: flex;
 5     justify-content: center;
 6     align-items: center;
 7 }
 8 .box{
 9     position: relative;
10     width: 250px;
11     margin:0 auto;
12 }
13 input{
14     text-align: center;
15     font: 40px/60px 'Microsoft YaHei';
16     width: 30%;
17     float:left;
18     box-sizing:border-box
19 }
20 button{
21     position: absolute;
22     bottom:-30px;
23     left: 50%;
24     margin-left: -30px;
25     width: 40px;
26 }

 

2、接下來重點來了,js部分

之前已經說了js的實現的方法,一下是相關代碼。

 1 var oBtn=document.getElementsByTagName('button')[0],
 2   aInp=document.getElementsByTagName('input');
 3 function isNum(){
 4   var aTemp=[];//創建臨時數組,依次存放九宮格中的數字
 5   for(i=0;i<aInp.length;i++)
 6   {
 7     var val=Number(aInp[i].value);
 8     if(isNaN(val) || val<1 || val>9) {//判斷當前輸入框中數值是否是數字,是否小於1,是否大於9?
 9       alert('1、您只能輸入1-9純數字;2、不能為空;');
10       return false;//若滿足任意一條件直接退出函數不往下走
11     }
12     for(s=0;s<aTemp.length;s++){//迴圈判斷九宮格內是否有重覆數值,若是有重覆直接退出函數
13       if(val == aTemp[s]){
14         alert('不能重覆輸入!');
15         return false;
16       }
17     }
18     //上述判斷都滿足,則將當前val的值放到數組aTemp中
19     aTemp.push(val);
20   }
21   //n後面所跟數字與上面圖片每個格子標記的數值一致
22   //將橫向與縱向的值設置為0;其中n1-n3為橫向三個值,n4-n6為縱向三個值
23   var n1=0,n2=0,n3=0,n4=0,n5=0,n6=0,
24   //n7、n8分別為兩對角值
25     n7=aTemp[0]+aTemp[4]+aTemp[8],
26     n8=aTemp[2]+aTemp[4]+aTemp[6];
27   //橫向:分段相加值
28   for(i=0;i<3;i++)n1+=aTemp[i];
29   for(i=3;i<6;i++)n2+=aTemp[i];
30   for(i=6;i<9;i++)n3+=aTemp[i];
31   //縱向:因為縱向是每隔兩個格子相加一次,所以正好用取模方式計算
32   
33   for(i=0;i<9;i++){
34     (i%3==0) && (n4+=aTemp[i]);//當i%3=0時,分別為格子0、3、6
35     (i%3==1) && (n5+=aTemp[i]);//當i%3=1時,分別為格子1、4、7
36     (i%3==2) && (n6+=aTemp[i]);//當i%3=1時,分別為格子2、5、8
37   }
38   //判斷n1-n8各值是否都相等,當然可以任意一個n判斷,不局限只與n1的值相等
39   n1==n2 && n1==n3 && n1==n4 && n1==n5 && n1==n6 && n1==n7 && n1==n8 ? alert('恭喜您輸入正確!')  : alert('很遺憾您輸入錯誤!');
40 }
41 oBtn.onclick=isNum;

 

執行效果

  1、當輸入數值為非數字,或大於9,或小於0,或為空時

2、當輸入重覆數字時

3、當輸入正確時

 

源碼下載http://files.cnblogs.com/files/web-cxn/%E4%B9%9D%E5%AE%AB%E6%A0%BC%E6%BA%90%E7%A0%81.rar


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1.獲取當前時間 function getNowTime() { return new Date(); } 2.時間與天數相加 function getTimeAddDays(time, days) { return new Date(time.getTime() + days * 24 * 60
  • <!DOCTYPE html> <!--[if IE]> <meta http-equiv="X-UA-Compatible" content="IE=8" /> <![endif]--> <!--[if IE 7]> <meta http-equiv="X-UA-Compatible" conte
  • jQuery獲取Select選擇的Text和Value: 語法解釋: 1. $("#select_id").change(function(){//code...}); //為Select添加事件,當選擇其中一項時觸發 2. var checkText=$("#select_id").find("o
  • //get base URL var _urlstr = window.location.href; if (_urlstr.indexOf("?") > -1) { _urlstr = _urlstr.substring(0, _urlstr.lastIndexOf("?")); } _urlst
  • 有幾種方法:①CSS處理方法(僅IE) #backGroundImg { background-image: url("X.png"); background-repeat: no-repeat; filter:progid:dximagetransform.microsoft.alphaimage
  • 在數據添加到DOM時候,我們可以需要對內容進行HtmlEncode或JavaScriptEncode,以預防XSS攻擊。 JavaScriptEncode 使用“\”對特殊字元進行轉義,除數字字母之外,小於127的字元編碼使用16進位“\xHH”的方式進行編碼,大於用unicode(非常嚴格模式)。
  • magic Toolbox是一款處理圖像的javascript插件,這款插件號稱用戶僅需五分鐘便可讓網站擁有酷炫的效果。我個人認為在用戶體驗方面做得相當不錯,最讓我滿意的是支持PC端及跨移動設備的用戶體驗。magicToolBox主要有六大功能,分別為:Magic Zoom、Magic Zoom P
  • firefox不支持background-position-x background-position-y,使用background-position:5px 5px;
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...