成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術(shù)文章
文章詳情頁

JavaScript實現(xiàn)網(wǎng)頁版五子棋游戲

瀏覽:101日期:2023-05-30 18:54:10

本文實例為大家分享了JavaScript實現(xiàn)網(wǎng)頁版五子棋游戲的具體代碼,供大家參考,具體內(nèi)容如下

學(xué)習(xí)js的第三天,跟著老師完成的五子棋小游戲,記錄學(xué)習(xí)成果歡迎大佬們一起分享經(jīng)驗,批評指正。

本程序主要通過三部分實現(xiàn):

1.棋盤繪制2.鼠標(biāo)交互3.輸贏判斷

<!DOCTYPE html><html><head> <title> canvastest </title></head><body> <h1> canvas</h1> <canvas id='canvas'width='400'height='400'> </canvas> <script src='https://cdn.bootcdn.net/ajax/libs/jquery/3.6.0/jquery.js'></script> <script> var canv=document.getElementById('canvas'); var ctx=canv.getContext('2d'); ctx.strokeStyle='black'; var bow=0;//畫出棋盤;var matrix=[ [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0], [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0], [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0], [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0], [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0], [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0], [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0], [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0], [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0], [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0], [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0], [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0], [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0], [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0], [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0], [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0], [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0], [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0], [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0], ];ctx.beginPath();for(var i=0;i<19;i++){ ctx.moveTo(10+20*i,10); ctx.lineTo(10+i*20,370); ctx.moveTo(10,20*i+10); ctx.lineTo(370,i*20+10);} ctx.stroke(); //鼠標(biāo)交互; $('#canvas').click(function(event) { console.log(event.offsetX) console.log(bow); var arcPosX,arcPosY; var mtxPosX,mtxPosY; for(var x=0;x<19;x++) { if((Math.abs(event.offsetX-(10+x*20)))<10){ arcPosX=10+x*20; mtxPosX=x;} if((Math.abs(event.offsetY-(10+x*20)))<10) {arcPosY=10+x*20;mtxPosY=x; } } if(matrix[mtxPosX][mtxPosY] == 0) { bow=!bow; ctx.beginPath(); if(bow){ ctx.fillStyle='Black'; ctx.arc(arcPosX,arcPosY,10,0,Math.PI*2,false); matrix[mtxPosX][mtxPosY]=1; } else{ ctx.fillStyle='White'; ctx.arc(arcPosX,arcPosY,10,0,Math.PI*2,false); ctx.stroke(); matrix[mtxPosX][mtxPosY]=2; } ctx.fill(); } //實現(xiàn)輸贏判斷 var winFlag=0;if(winFlag==0){if(matrix[mtxPosX-1][mtxPosY] == matrix[mtxPosX][mtxPosY]) { if(matrix[mtxPosX-2][mtxPosY] == matrix[mtxPosX][mtxPosY]) {if(matrix[mtxPosX-3][mtxPosY] == matrix[mtxPosX][mtxPosY]){ if(matrix[mtxPosX-4][mtxPosY] == matrix[mtxPosX][mtxPosY]) { winFlag = 1; } else { if(matrix[mtxPosX+1][mtxPosY] == matrix[mtxPosX][mtxPosY]) { winFlag = 1; } else { winFlag = 0; } }}else{ for(var w = 0; w < 2 ; w ++) { if(matrix[mtxPosX+w+1][mtxPosY] != matrix[mtxPosX][mtxPosY]) { winFlag = 0; break; } else { winFlag = 1; } }} } else {for(var w = 0; w < 3 ; w ++){ if(matrix[mtxPosX+w+1][mtxPosY] != matrix[mtxPosX][mtxPosY]) { winFlag = 0; break; } else { winFlag = 1; }} } } else { for(var w = 0; w < 4 ; w ++) {if(matrix[mtxPosX+w+1][mtxPosY] != matrix[mtxPosX][mtxPosY]){ winFlag = 0; break;}else{ winFlag = 1;} } }if(matrix[mtxPosX][mtxPosY-1] == matrix[mtxPosX][mtxPosY]) { if(matrix[mtxPosX][mtxPosY-2] == matrix[mtxPosX][mtxPosY]) {if(matrix[mtxPosX][mtxPosY-3] == matrix[mtxPosX][mtxPosY]){ if(matrix[mtxPosX][mtxPosY-4] == matrix[mtxPosX][mtxPosY]) { winFlag = 1; } else { if(matrix[mtxPosX][mtxPosY+1] == matrix[mtxPosX][mtxPosY]) { winFlag = 1; } else { winFlag = 0; } }}else{ for(var w = 0; w < 2 ; w ++) { if(matrix[mtxPosX][mtxPosY+w+1] != matrix[mtxPosX][mtxPosY]) { winFlag = 0; break; } else { winFlag = 1; } }} } else {for(var w = 0; w < 3 ; w ++){ if(matrix[mtxPosX][mtxPosY+w+1] != matrix[mtxPosX][mtxPosY]) { winFlag = 0; break; } else { winFlag = 1; }} } } else { for(var w = 0; w < 4 ; w ++) {if(matrix[mtxPosX][mtxPosY+w+1] != matrix[mtxPosX][mtxPosY]){ winFlag = 0; break;}else{ winFlag = 1;} } } if(matrix[mtxPosX-1][mtxPosY-1] == matrix[mtxPosX][mtxPosY]){ if(matrix[mtxPosX-2][mtxPosY-2] == matrix[mtxPosX][mtxPosY]) { if(matrix[mtxPosX-3][mtxPosY-3] == matrix[mtxPosX][mtxPosY]) { if(matrix[mtxPosX-4][mtxPosY-4] == matrix[mtxPosX][mtxPosY]) { winFlag = 1; } else { if(matrix[mtxPosX+1][mtxPosY+1] == matrix[mtxPosX][mtxPosY]) { winFlag = 1; } else { winFlag = 0; } } } else { for(var w = 0; w < 2 ; w ++) { if(matrix[mtxPosX+w+1][mtxPosY+w+1] != matrix[mtxPosX][mtxPosY]) { winFlag = 0; break; } else { winFlag = 1; } } } } else { for(var w = 0; w < 3 ; w ++) { if(matrix[mtxPosX+w+1][mtxPosY+w+1] != matrix[mtxPosX][mtxPosY]) { winFlag = 0; break; } else { winFlag = 1; } } }}else{ for(var w = 0; w < 4 ; w ++) { if(matrix[mtxPosX+w+1][mtxPosY+w+1] != matrix[mtxPosX][mtxPosY]) { winFlag = 0; break; } else { winFlag = 1; } } } if(matrix[mtxPosX-1][mtxPosY+1] == matrix[mtxPosX][mtxPosY]) { if(matrix[mtxPosX-2][mtxPosY+2] == matrix[mtxPosX][mtxPosY]) {if(matrix[mtxPosX-3][mtxPosY+3] == matrix[mtxPosX][mtxPosY]){ if(matrix[mtxPosX-4][mtxPosY+4] == matrix[mtxPosX][mtxPosY]) { winFlag = 1; } else { if(matrix[mtxPosX+1][mtxPosY-1] != matrix[mtxPosX][mtxPosY]) { winFlag = 0; } else { winFlag = 1; } }}else{ for(var w = 0; w < 2 ; w ++) { if(matrix[mtxPosX+w+1][mtxPosY-w-1] != matrix[mtxPosX][mtxPosY]) { winFlag = 0; break; } else { winFlag = 1; } }} } else {for(var w = 0; w < 3 ; w ++){ if(matrix[mtxPosX+w+1][mtxPosY-w-1] != matrix[mtxPosX][mtxPosY]) { winFlag = 0; break; } else { winFlag = 1; }} } } else { for(var w = 0; w < 4 ; w ++) {if(matrix[mtxPosX+w+1][mtxPosY-w-1] != matrix[mtxPosX][mtxPosY]){ winFlag = 0; break;}else{ winFlag = 1;} } } } if(winFlag ==1){ if(bow) alert('black win!'); else alert('white win!'); } }); </script></body></html>

JavaScript實現(xiàn)網(wǎng)頁版五子棋游戲

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: JavaScript
相關(guān)文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
亚洲欧美日韩另类精品一区二区三区 | 国产传媒一区在线| 翔田千里一区二区| 麻豆精品视频在线观看| 4438x成人网最大色成网站| 99久久免费视频.com| 久久综合久久99| 午夜视频一区| 欧美日韩午夜影院| 一区视频在线看| 久久精品国产**网站演员| 久久一区二区三区超碰国产精品| 欧美一区1区三区3区公司| 91在线国产福利| 成人一级片网址| 日精品一区二区三区| 日韩理论电影院| 久久久久久久免费视频了| 91麻豆精品91久久久久久清纯| 亚洲欧美视频一区| www.欧美日韩| 成人午夜精品在线| 美洲天堂一区二卡三卡四卡视频| 最新中文字幕一区二区三区| 欧美xxxxx裸体时装秀| 中文幕一区二区三区久久蜜桃| 色视频成人在线观看免| 亚洲精品一区在线观看| 亚洲成av人在线观看| 99精品国产热久久91蜜凸| 91久久精品国产91性色tv| 国产精品毛片高清在线完整版| 免费欧美日韩国产三级电影| 色综合久久综合网| 在线观看免费一区| 一区二区三区日韩在线观看| 成人福利视频网站| 欧美伊人久久久久久久久影院| 亚洲欧洲精品天堂一级| 中文字幕一区二区三区在线不卡 | 在线成人av| 日本道在线观看一区二区| 在线精品视频免费播放| 欧美剧情电影在线观看完整版免费励志电影 | 欧美亚洲综合色| 久久人人爽爽爽人久久久| 久久精品国产网站| 伊人一区二区三区| 亚洲国产日韩一级| 国产精品影视天天线| 国产精品一区专区| 女同性一区二区三区人了人一 | 国产丶欧美丶日本不卡视频| 欧美日韩精品免费观看| 91福利在线导航| 久久久久久9999| 亚洲电影在线播放| 国产综合久久久久影院| 一色屋精品视频在线看| 日韩一区二区视频| 一区二区三区蜜桃| 欧美激情视频一区二区三区在线播放 | 久久久久久久久久久电影| 中文字幕一区二区三中文字幕| 成人精品国产福利| 亚洲男人影院| 国产精品青草久久| 波多野结衣中文字幕一区二区三区| 亚洲美洲欧洲综合国产一区| 精品国产免费一区二区三区香蕉| 怡红院av一区二区三区| 午夜电影亚洲| 欧美成va人片在线观看| 久久精品国产网站| 色老头久久综合| 亚洲精品欧美综合四区| 日韩主播视频在线| 亚洲欧美成人| 亚洲免费观看高清完整版在线观看| 成人伦理片在线| 51精品视频一区二区三区| 久久成人羞羞网站| 717成人午夜免费福利电影| 狠狠久久亚洲欧美| 欧美日韩一级视频| 成人网在线播放| 欧美国产日本韩| 亚洲美女91| 日韩电影网1区2区| 日韩一区二区在线观看视频| 国产69精品一区二区亚洲孕妇| 欧美美女视频在线观看| 国产成人免费视频网站| 久久九九全国免费| 亚洲福利国产| 亚洲一区在线观看网站| 欧美视频一区在线| www.亚洲免费av| 亚洲精品写真福利| 欧美视频一区二区三区四区| 国产精品1区2区| 国产精品理论在线观看| 国产欧美日韩在线播放| 日韩精品乱码av一区二区| 欧美一级在线视频| 亚洲东热激情| 亚洲精品自拍动漫在线| 美女主播一区| 亚洲制服av| 午夜精品免费| 亚洲电影你懂得| 影音先锋久久| 亚洲狠狠爱一区二区三区| 夜夜嗨网站十八久久| 久久久久久久久蜜桃| 国产一区二区三区的电影| 国产精品亚洲人在线观看| 精品粉嫩超白一线天av| 国产精品狼人久久影院观看方式| 亚洲国产乱码最新视频| 91女厕偷拍女厕偷拍高清| 老司机午夜免费精品视频| 精品国产乱子伦一区| 国产精品久久一级| 欧美在线短视频| 91麻豆精品一区二区三区| 久久久五月婷婷| 亚洲免费激情| 国产精品99久久久久| 欧美一区二区啪啪| 欧美综合欧美视频| 亚洲一区二区三区精品动漫| 精品在线播放免费| 国产精品国产精品国产专区不片| 91精品国产综合久久久久久久久久| 欧美日韩综合久久| 91在线观看美女| 欧美激情一区| 91在线精品一区二区三区| 精品在线观看免费| 福利一区二区在线| 日韩电影在线免费看| 日韩1区2区3区| 亚洲一区二区三区免费视频| 久久久精品tv| 欧美成人艳星乳罩| 久久久久久久电影| 精品理论电影在线观看 | 中文一区一区三区高中清不卡| 国产精品久久久久久久久动漫 | 亚洲国产精品ⅴa在线观看| 国产精品久久久久影院| 视频一区二区三区在线| 亚洲最快最全在线视频| 欧美国产视频在线| 亚洲综合丝袜美腿| 国产成都精品91一区二区三| 欧美不卡高清| 99精品国产在热久久婷婷| 欧美一区午夜精品| 亚洲美女淫视频| 国产a视频精品免费观看| 一本综合精品| 久久久久久久久久久久久夜| 亚洲大片免费看| 在线日韩av永久免费观看| 欧美电影影音先锋| 日本中文在线一区| 亚洲国产日本| 国产人伦精品一区二区| 国产成人日日夜夜| 一本到不卡精品视频在线观看| 久久久久久久综合日本| 国产一区二区免费看| 色妹子一区二区| 亚洲一区免费视频| 一区免费在线| 亚洲男人的天堂在线aⅴ视频| 成人18视频在线播放| 日韩一区二区三区视频| 激情综合网av| 91精品国产91综合久久蜜臀| 美女久久久精品| 欧美日韩久久一区二区| 国产一区美女在线| 日韩午夜激情电影| 女女同性精品视频| 国产精品素人视频| 国产偷自视频区视频一区二区| 亚洲欧美日韩人成在线播放| 国产日韩视频| 黑人巨大精品欧美黑白配亚洲 | 久久成人精品| 久久丁香综合五月国产三级网站| 欧美性色综合网| 成人高清av在线| 亚洲少妇屁股交4| 在线成人av网站| 99精品在线免费| 亚洲你懂的在线视频|