基于javascript制作經(jīng)典傳統(tǒng)的拼圖游戲
本文實(shí)例為大家分享了javascript制作經(jīng)典傳統(tǒng)的拼圖游戲的關(guān)鍵代碼,供大家參考,具體內(nèi)容如下
效果圖:
拼出你喜歡的白雪公主和七個(gè)小矮人
實(shí)現(xiàn)代碼:
<!DOCTYPE html> <html> <head> <title>pingtu.html</title> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="this is my page"> <meta http-equiv="content-type" content="text/html; charset=gb2312"> <!--<link rel="stylesheet" type="text/css" href="./styles.css">--> <style type="text/css"> *{ margin-bottom:0px; margin-top: 0px; margin-left: 0px; margin-right: 0px; padding-right: 0px; padding-left: 0px; padding-top: 0px; padding-bottom: 0px; border: 0px; } #box{ position:absolute; top:0px; left:0px; width: 300px; height: 300px; border: 1px solid red; } #box img{ float:left; width: 100px; height: 100px; } #box .pj,#box .p2,#box .p3,#box .p4,#box .p5,#box .p6,#box .p7,#box .p8,#box .p9{ position: absolute; } #box .pj,#box .p2,#box .p3{ top:0px; } #box .p4,#box .p5,#box .p6{ top:100px; } #box .p7,#box .p8,#box .p9{ top:200px; } #box .pj,#box .p4,#box .p7{ left:0px; } #box .p2,#box .p5,#box .p8{ left:100px; } #box .p3,#box .p6,#box .p9{ left:200px; } #button{ font-size:25px; font-weight:20px; float: left; position: absolute; top:400px; left:100px; } #output{ position:absolute; width: 270px; height: 170px; top:130px; left: 350px; } #output img{ height: 170px; width:170px; float: right; } #notice{ position: absolute; left: 650px; top:150px; width: 150px; height: 120px; border: 1px solid blue; font-size: 15px; } </style> </head> <body> <div id="box"> <img class="pj" src="img1/pj.png"> <img class="p2" src="img1/p2.png"> <img class="p3" src="img1/p3.png"> <img class="p4" src="img1/p4.png"> <img class="p5" src="img1/p5.png"> <img class="p6" src="img1/p6.png"> <img class="p7" src="img1/p7.png"> <img class="p8" src="img1/p8.png"> <img class="p9" src="img1/p9.png"> </div> <div id="output"> 目標(biāo)圖形: <img alt="" src="img1/output.jpg"> </div> <div id="notice"> 游戲提示:<br> <br> 點(diǎn)擊“開始新游戲”開始游戲。鼠標(biāo)點(diǎn)擊黑色方塊周圍的方塊時(shí),即可移動(dòng)方塊。。 </div> <input type="button" id="button" value="開始新游戲"> <script type="text/javascript"> var times=0; var src= Array(); src.push("img1/pj.png"); src.push("img1/p2.png"); src.push("img1/p3.png"); src.push("img1/p4.png"); src.push("img1/p5.png"); src.push("img1/p6.png"); src.push("img1/p7.png"); src.push("img1/p8.png"); src.push("img1/p9.png"); function addLoadEvent(func) { //為window添加新事件函數(shù) var oldonload = window.onload; if (typeof window.onload != 'function') { window.onload = func; } else { window.onload = function() { oldonload(); func(); }; } } function getInfor(){ var ps=document.getElementById("box"); var Arrps=ps.getElementsByTagName("img"); for(var i=0;i<Arrps.length;i++){ Arrps[i].onclick=function(){ if (this.getAttribute("src")=="img1/pj.png"); changeP(this,Arrps); }; } } function tostar(){ var butt=document.getElementById("button"); butt.onclick=function(){ toST(); times=0; getInfor(); }; } function changeP(ob,Arrps){ var Ni=0; var Nj=0; for(var i=0;i<Arrps.length;i++){ if(Arrps[i]==ob) Ni=i; if(Arrps[i].getAttribute("src")=="img1/pj.png") Nj=i; } if(Math.abs(Ni-Nj)==3) { var temperOb=ob.getAttribute("src"); ob.setAttribute("src","img1/pj.png"); Arrps[Nj].setAttribute("src",temperOb); times++; ifright(); }else if((Ni-Nj)==1&&(Ni%3)!=0){ var temperOb=ob.getAttribute("src"); ob.setAttribute("src","img1/pj.png"); Arrps[Nj].setAttribute("src",temperOb); times++; ifright(); }else if((Ni-Nj)==-1&&(Ni%3)!=2){ var temperOb=ob.getAttribute("src"); ob.setAttribute("src","img1/pj.png"); Arrps[Nj].setAttribute("src",temperOb); times++; ifright(); } } function ifright(){ var ps=document.getElementById("box"); var Arrps=ps.getElementsByTagName("img"); for(var i=0;i<src.length;i++){ if(src[i]!=Arrps[i].getAttribute("src")) return; } if(times<50) alert("恭喜,你成功了。。"+"\n"+"僅用了"+times+"步哦"); else alert("恭喜,你成功了。。"+"\n"+"用了"+times+"步"); } function toST(){ var srcUsing= new Array(); for(var p=0; p<src.length;p++){ srcUsing[p]=src[p]; } var ps=document.getElementById("box"); var Arrps=ps.getElementsByTagName("img"); var newArry= new Array(); for(var i=0;i<Arrps.length;i++){ newArry.push(srcUsing.splice(Math.floor(Math.random()*srcUsing.length), 1)); } for(var j=0;j<newArry.length;j++) { //var newarrValue=newArry[j]; Arrps[j].setAttribute("src",String(newArry[j])); } } addLoadEvent(tostar); </script> </body> </html>
希望本文所述對(duì)大家學(xué)習(xí)javascript程序設(shè)計(jì)有所幫助,讓大家動(dòng)手親自實(shí)現(xiàn)自己最喜愛的游戲——拼圖。
- JS快速實(shí)現(xiàn)移動(dòng)端拼圖游戲
- JS 拼圖游戲 面向?qū)ο?,注釋完整?/a>
- js+html5實(shí)現(xiàn)可在手機(jī)上玩的拼圖游戲
- JS實(shí)現(xiàn)拼圖游戲
- jQuery+vue.js實(shí)現(xiàn)的九宮格拼圖游戲完整實(shí)例【附源碼下載】
- 基于Vue.js實(shí)現(xiàn)數(shù)字拼圖游戲
- 利用原生的JavaScript實(shí)現(xiàn)簡(jiǎn)單拼圖游戲
- javascript結(jié)合Flexbox簡(jiǎn)單實(shí)現(xiàn)滑動(dòng)拼圖游戲
- 基于JS實(shí)現(xiàn)簡(jiǎn)單滑塊拼圖游戲
- 使用js編寫實(shí)現(xiàn)拼圖游戲
相關(guān)文章
web-view內(nèi)嵌H5與uniapp數(shù)據(jù)的實(shí)時(shí)傳遞解決方案
這篇文章主要介紹了web-view內(nèi)嵌H5與uniapp數(shù)據(jù)的實(shí)時(shí)傳遞,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-07-07JavaScript求解最長(zhǎng)回文子串的方法分享
這篇文章主要為大家介紹了JavaScript求解最長(zhǎng)回文子串的幾種方法,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2022-08-08js實(shí)現(xiàn)仿愛微網(wǎng)兩級(jí)導(dǎo)航菜單效果代碼
這篇文章主要介紹了js實(shí)現(xiàn)仿愛微網(wǎng)兩級(jí)導(dǎo)航菜單效果代碼,通過javascript自定義函數(shù)結(jié)合鼠標(biāo)點(diǎn)擊事件實(shí)現(xiàn)tab切換的功能,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-08-08js判斷iframe中元素是否存在的實(shí)現(xiàn)代碼
這篇文章主要介紹了js判斷iframe中元素是否存在的實(shí)現(xiàn)代碼,需要的朋友可以參考下2016-12-12用console.table()調(diào)試javascript
昨天我了解到Chrome調(diào)試工具一個(gè)小巧的調(diào)試方法,在WDCC期間, Marcus Ross(@zahlenhelfer) 介紹了,chrome調(diào)試工具各種調(diào)試方法,這個(gè)只是其中一種,現(xiàn)在我來給大家秀下。2014-09-09