jQuery實現拼圖小游戲

来源:http://www.cnblogs.com/zihuatanejoyn/archive/2017/07/23/7226252.html
-Advertisement-
Play Games

小熊維尼拼圖 2017-07-23 21:59:48 jQuery代碼實現拼圖小游戲,滑鼠選中拼塊,用上下左右鍵移動拼塊。 效果展示 html代碼 1 <div id="box-div"> 2 <!--走不通時的提示!--> 3 <div id="tips"> 4 <p>\(╯-╰)/ 哎呦,走不通 ...


小熊維尼拼圖                                                                                    2017-07-23       21:59:48

jQuery代碼實現拼圖小游戲,滑鼠選中拼塊,用上下左右鍵移動拼塊。

 

photo1 效果展示 html代碼
 1 <div id="box-div">
 2     <!--走不通時的提示!-->
 3     <div id="tips">
 4         <p>\(╯-╰)/ 哎呦,走不通啦!</p>
 5     </div>
 6     <div id="container">
 7         <div class="row">
 8             <div class="unit"><img src="http://yn321.cn3v.net/images/weini_part_01.png" alt="photo1"/></div>
 9             <div class="unit"><img src="http://yn321.cn3v.net/images/weini_part_02.gif" alt="photo2"/></div>
10             <div class="unit"><img src="http://yn321.cn3v.net/images/weini_part_03.gif" alt="photo3"/></div>
11         </div>
12         <div class="row">
13             <div class="unit"><img src="http://yn321.cn3v.net/images/weini_part_04.gif" alt="photo4"/></div>
14             <div class="unit"><img src="http://yn321.cn3v.net/images/weini_part_05.gif" alt="photo5"/></div>
15             <div class="unit"><img src="http://yn321.cn3v.net/images/weini_part_06.gif" alt="photo6"/></div>
16         </div>
17         <div class="row">
18             <div class="unit"><img src="http://yn321.cn3v.net/images/weini_part_07.gif" alt="photo7"/></div>
19             <div class="unit"><img src="http://yn321.cn3v.net/images/weini_part_08.gif" alt="photo8"/></div>
20             <div class="unit"><img src="http://yn321.cn3v.net/images/weini_part_09.gif" alt="photo9"/></div>
21         </div>
22     </div>
23 </div
 1 #box-div {
 2     position: relative;
 3     width: 508px;
 4     height: 631px;
 5     margin: 0 auto;
 6 }
 7 
 8 #container {
 9     width: 508px;
10     height: 631px;
11     margin: 0 auto;
12     -webkit-box-sizing: border-box;
13     -moz-box-sizing: border-box;
14     box-sizing: border-box;
15     border: 1px solid #d5e0e6;
16 }
17 
18 #container > .row {
19     display: -webkit-box;
20     white-space: nowrap;
21 }
22 
23 #container > .row > .unit {
24     width: 169px;
25     height: 209px;
26     display: inline-block\9;/*相容IE9/10*/
27     vertical-align: top\9;/*相容IE9/10*/
28     box-sizing: border-box;
29     border: 1px solid rgba(7, 157, 239, 0);
30 }
31 
32 #container > .row > .unit.move {
33     border: 1px solid rgba(7, 157, 239, 1);
34 }
35 
36 #tips {
37     width: 200px;
38     height: 50px;
39     background: rgb(152, 206, 50);
40     position: absolute;
41     z-index: 5;
42     top: -50px;
43     left: calc(50% - 100px);
44     opacity: 0;
45 }
46 
47 #tips > p {
48     margin: 0;
49     line-height: 50px;
50     text-align: center;
51     color: white;
52 }
53 .directions{
54     width:50%;
55     margin:0 auto;
56     text-align: center;
57     line-height: 30px;
58     color: white;
59     background-color: #a7cbf0;
60 }
  jquery代碼
 1 $("#container>.row>.unit>img").each(function () {
 2     $(this).click(function (event) {
 3         event.stopPropagation();
 4         $(".unit").removeClass("move");
 5         $(this).parent(".unit").addClass("move");
 6     })
 7 });
 8 move(".move","#tips");
 9 function move(className,idName) {
10     /* 提示信息 */
11     function tipsAlert(idName) {
12         $(idName).animate({top: "0", opacity: "1"}, 500);
13         setTimeout(function () {
14             $(idName).animate({top: "-50px", opacity: "0"}, 800);
15         }, 1000)
16     }
17     /* 上下左右按鍵移動 */
18     $(document).keydown(function (e) {
19         var code = e.keyCode;
20         if (code > 40 || code < 37) {
21             return false;
22         }
23         var prev = $(className)[0].previousElementSibling;//選中元素前置位元素是否存在,以此判斷元素是否還可以左右移動
24         var next = $(className)[0].nextElementSibling;//選中元素後置位元素是否存在,以此判斷元素是否還可以左右移動
25         var paprev = $(className).parent()[0].previousElementSibling;//選中元素父級前置位元素是否存在,以此判斷元素是否還可以上下移動
26         var panext = $(className).parent()[0].nextElementSibling;//選中元素父級後置位元素是否存在,以此判斷元素是否還可以上下移動
27         var index = $(className).index();//根據選中元素的索引值,來確定上下移動時對換的位置
28         var movenDiv = $(className).next()[0];//以此確定上下對換元素添加方式
29         var movepDiv = $(className).prev()[0];//以此確定上下對換元素添加方式
30         switch (code) {
31             case 37://
32                 if (prev) {
33                     $(className).insertBefore(prev);
34                 } else {
35                     tipsAlert(idName);
36                 }
37                 break;
38             case 38://
39                 if (paprev) {
40                     var exchangeTop = $(paprev).children()[index];
41                     $(className).insertBefore(exchangeTop);
42                     if (movenDiv) {
43                         $(exchangeTop).insertBefore(movenDiv);
44                     } else {
45                         $(exchangeTop).insertAfter(movepDiv)
46                     }
47 
48                 } else {
49                     tipsAlert(idName);
50                 }
51                 break;
52             case 39://
53                 if (next) {
54                     $(className).insertAfter(next);
55                 } else {
56                     tipsAlert(idName)
57                 }
58                 break;
59             case 40://
60                 if (panext) {
61                     var exchangeBottom = $(panext).children()[index];
62                     $(className).insertBefore(exchangeBottom);
63                     if (movenDiv) {
64                         $(exchangeBottom).insertBefore(movenDiv);
65                     } else {
66                         $(exchangeBottom).insertAfter(movepDiv)
67                     }
68                 } else {
69                     tipsAlert(idName);
70                 }
71                 break;
72 
73         }
74     });
75 
76 
77 }

菜鳥一隻,僅供參考,歡迎留言更好的代碼建議,謝謝啦!


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

-Advertisement-
Play Games
更多相關文章
  • 程式聲明將整型變數的類型告訴了C++編譯器,但編譯器如何知道常量類型呢? 除非有理由(如使用特殊尾碼,或者值太大無法存儲為int),不然都將存儲為int類型 尾碼是放在數字常量後面的字母 l、L表示long常量 u、U表示unsigned int ul(UL)或lu(LU)表示unsigned in ...
  • 我們以騰訊社招頁面來做示例:http://hr.tencent.com/position.php?&start=0#a 如上圖,使用BeautifulSoup4解析器,將圖1中229頁,每頁10個招聘信息,共2289個招聘信息中的職位名稱、職位類別、招聘人數、工作地點、工作職責、工作要求、詳情鏈接等 ...
  • Message Digest Algorithm MD5(中文名為消息摘要演算法第五版)為電腦安全領域廣泛使用的一種散列函數,用以提供消息的完整性保護。該演算法的文件號為RFC 1321(R.Rivest,MIT Laboratory for Computer Science and RSA Data ...
  • 在我們做後臺刪除的時候,當點擊刪除標簽時,你希望彈出一個友好的提示框!比如這樣: 那代碼應該怎樣寫呢?向下麵這樣? 你會發現會發生這樣一個錯誤: 該函數沒有被使用?不應該啊,我在php裡面不是已經調用了麽? 註意: 想必寫過前端的人都知道這個方法是在頁面全部載入完成之後執行,那麼問題就來了,php的 ...
  • shutil模塊 高級的 文件、文件夾、壓縮包 處理模塊 os模塊提供了對目錄或者文件的新建/刪除/查看文件屬性,還提供了對文件以及目錄的路徑操作。比如說:絕對路徑,父目錄…… 但是,os文件的操作還應該包含移動 複製 打包 壓縮 解壓等操作,這些os模塊都沒有提供。 而本文所講的shutil則就是 ...
  • sys模塊 sys模塊是處理與系統相關的模塊,sys(system),下麵來看看sys模塊常用的方法: 1、sys.argv #命令行參數list,第一個元素是程式本身路徑 2、sys.exit(n) #退出程式,正常退出時exit(0) 功能:執行到主程式末尾,解釋器自動退出,但是如果需要中途退出 ...
  • 快速排序演算法思想: 快速排序(Quicksort)是對冒泡排序的一種改進。 快速排序由C. A. R. Hoare在1962年提出。它的基本思想是:通過一趟排序將要排序的數據分割成獨立的兩部分,其中一部分的所有數據都比另外一部分的所有數據都要小,然後再按此方法對這兩部分數據分別進行快速排序,整個排序 ...
  • 棧:自動分配連續的空間,後進先出。用於存放局部變數 Example:s1(局部變數。new出來以後放到堆里保存) s1中存放一個地址,指向堆中保存的對象,對象中的各種屬性也各自存放一個地址,指向堆內方法區中所保存的代碼、static變數以及常量池等。圖例如下 堆:空間不連續。用於放置new出的對象 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...