版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
第js實現(xiàn)數(shù)字拼圖本文實例為大家分享了js實現(xiàn)數(shù)字拼圖的具體代碼,供大家參考,具體內(nèi)容如下
重點:
游戲區(qū)分為8個div,進行游戲時需要判斷點擊的div是否可移動,移動后判斷游戲是否結(jié)束。
解決思路:將游戲界面看作一個div大盒子,將大盒子分為9個區(qū)域進行編號,這9個區(qū)域的位置始終不變;8個div以定位top和left控制其位置,設(shè)置9個區(qū)域的div分別可以往哪個區(qū)域移動,點擊時判斷可移動的編號區(qū)域內(nèi)是否有div,若有,則無法向該方向移動。每次移動后檢查8個div的編號是否與區(qū)域的編號完全重合,若重合,則通關(guān)。
運行情況
HTML
divid="container"
!--最外面的DIV,用來包含里面的結(jié)構(gòu)--
divid="game"
!--游戲區(qū),也就是大DIV方塊--
divid="d1"1/div
divid="d2"2/div
divid="d3"3/div
divid="d4"4/div
divid="d5"5/div
divid="d6"6/div
divid="d7"7/div
divid="d8"8/div
/div
divid="control"
!--游戲控制區(qū)--
p
總用時:
spanid="timer"/span
/p
!--顯示游戲時間區(qū)域--
p
buttonid="start"開始/button
buttonid="reset"重來/button
/p
!--顯示控制按鈕區(qū)域--
/div
/div
CSS
*{
padding:0;
margin:0;
border:0;
}
body{
width:100%;
height:100%;
}
#container{
position:relative;
width:620px;
height:450px;
margin:0auto;
margin-top:100px;
border-radius:1px;
}
#game{
position:absolute;
width:450px;
height:450px;
border-radius:5px;
display:inline-block;
background-color:#ffe171;
box-shadow:0010px#ffe171;
}
#gamediv{
position:absolute;
width:149px;
height:149px;
box-shadow:1px1px2px#777;
background-color:#20a6fa;
color:white;
text-align:center;
font-size:150px;
line-height:150px;
cursor:pointer;
transition:0.3s;
}
#gamediv:hover{
color:#ffe171;
}
#control{
width:150px;
height:450px;
display:inline-block;
position:absolute;
top:0;
right:0;
}
#controlbutton{
height:25px;
font-size:20px;
color:#222;
margin-top:10px;
}
#start{
display:inline-block;
font-size:28px;
width:100px;
height:28px;
background-color:#20a6fa;
color:#ffe171;
text-shadow:1px1px2px#ffe171;
border-radius:5px;
box-shadow:2px2px5px#4c98f5;
text-align:center;
/*cursor:pointer讓鼠標(biāo)移到元素上面顯示不同的鼠標(biāo)形狀,pointer是手型*/
cursor:pointer;
}
#reset{
display:inline-block;
font-size:28px;
width:100px;
height:28px;
background-color:#20a6fa;
color:#ffe171;
text-shadow:1px1px2px#ffe171;
border-radius:5px;
box-shadow:2px2px5px#4c98f5;
text-align:center;
cursor:pointer;
}
#d1{
left:0px;
}
#d2{
left:150px;
}
#d3{
left:300px;
}
#d4{
top:150px;
}
#d5{
top:150px;
left:150px;
}
#d6{
top:150px;
left:300px;
}
#d7{
top:300px;
}
#d8{
left:150px;
top:300px;
}
JS
vartime=0;
//添加暫停判斷
varpause=true;
varset_timer;
//創(chuàng)建編號,不使用第一個元素
vard=newArray(10);
for(vari=1;ii++){
d[i]=i;
}
d[9]=0;
//大div編號可移動的位置
vard_direct=newArray(
[0],[2,4],[1,3,5],[2,6],[1,5,7],[2,4,6,8],[3,5,9],[4,8],[5,7,9],[6,8]
);
//大div編號的位置[left,top]
vard_posXY=newArray(
[0],[0,0],[150,0],[300,0],[0,150],[150,150],[300,150],[0,300],[150,300],[300,300]
);
vargame=document.querySelectorAll('#gamediv');
for(vari=0;igame.length;i++){
varj=i+1;
game[i].setAttribute('index',j);
game[i].addEventListener('click',function(e){
move(e,e.target.getAttribute('index'));
});
}
//移動
functionmove(e,id){
//查找小div在大div中的位置
vari=1;
for(i=1;ii++){
if(d[i]==id){
break;
}
}
//查找小div可移動的位置,0則無法移動
vartarget_d=0;
target_d=whereCanTo(i);
//判斷當(dāng)前被點擊的小div是否可移動
if(target_d!=0){
//設(shè)置當(dāng)前大div編號為0
d[i]=0;
//將目標(biāo)大div編號設(shè)置為被點擊的小div編號
d[target_d]=id;
//設(shè)置被點擊小div的位置
document.getElementById('d'+id).style.left=d_posXY[target_d][0]+'px';
document.getElementById('d'+id).style.top=d_posXY[target_d][1]+'px';
}
//判斷游戲是否完成
varfinish_flag=true;
for(vark=1;kk++){
if(d[k]!=k){
finish_flag=false;
break;
}
}
if(finish_flag==true){
if(!pause){
start();
alert('bingocongratulation!');
}
}
}
//查找并返回小div可以移動的編號
functionwhereCanTo(cur_div){
varj=0;
varmove_flag=false;
for(j=0;jd_direct[cur_div].length;j++){
if(d[d_direct[cur_div][j]]==0){
move_flag=true;
break;
}
}
if(move_flag==true){
returnd_direct[cur_div][j];
}else{
return0;
}
}
//設(shè)置計時
functiontimer(){
time+=1;
varmin=parseInt(time/60);
vars=time%60;
document.getElementById('timer').innerHTML=min+'分'+s+'秒';
}
//開始暫停
varstart=document.querySelector('#start');
start.addEventListener('click',sta);
functionsta(){
if(pause){
start.innerHTML='暫停';
pause=false;
set_timer=setInterval(timer,1000);
}else{
start.innerHTML='開始';
pause=true;
clearInterval(set_timer);
}
}
//重置游戲
varreset=document.querySelector('#reset');
reset.addEventListener('click',res);
functionres(){
time=0;
random_d();
if(pause){
sta();
}
}
//隨機打亂
functionrandom_d(){
for(vari=9;ii--){
varto=parseInt(Ma
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2026廣東惠州市博羅縣中小企業(yè)發(fā)展事務(wù)中心招聘編外人員1人備考題庫含答案詳解
- 食品不合格食品處置制度
- 2026江西吉安市新供商貿(mào)物流有限公司招募就業(yè)見習(xí)人員2人備考題庫及答案詳解參考
- 罕見腫瘤的個體化治療藥物相互作用管理策略與決策-3
- 2026江西安源路橋集團有限公司外聘人員招聘2人備考題庫有答案詳解
- 2026廣西百色市事業(yè)單位招聘1563人備考題庫有答案詳解
- 罕見腫瘤的個體化治療生活質(zhì)量干預(yù)措施與心理需求
- 少兒培訓(xùn)財務(wù)制度
- 砂石礦財務(wù)制度
- 建筑工程業(yè)財務(wù)制度
- 2026年人力資源共享服務(wù)中心建設(shè)方案
- JJG(交通) 141-2017 瀝青路面無核密度儀
- 風(fēng)電場高效風(fēng)機選型方案
- 石材加工成本與報價分析報告
- 基于人工智能的腦卒中預(yù)后預(yù)測方案
- 幾何形體結(jié)構(gòu)素描教案
- 安全員(化工安全員)國家職業(yè)標(biāo)準(zhǔn)(2025年版)
- 制袋車間操作規(guī)范及培訓(xùn)手冊
- 2025組織生活會問題清單及整改措施
- 四川省成都市簡陽市2026屆數(shù)學(xué)七上期末監(jiān)測試題含解析
- HPV檢測與分型課件
評論
0/150
提交評論