本文实例为大家分享了js实现五子棋游戏的具体代码,供大家参考,具体内容如下
html:
<body> <h2>五子棋游戏</h2> <div id="box"> <div id="box01"></div> <div id="box02">haha</div> </div> </body>
css:
<style type="text/css"> *{ margin: 0; padding: 0; } body{ /*overflow: hidden;*/ margin-top: 10px; text-align: center; background-color: #C7C7C7; } #box{ position: relative; border: 1px solid; margin: 20px auto; width: 546px; height: 546px; background-color: #C7C7C7; } #box .squre{ width: 40px; height: 40px; border: 1px solid; float: left; } #box01 .squre:hover{ background-color: pink; } #box01{ position: absolute; /*border: 1px solid;*/ margin: 0 auto; width: 588px; height: 588px; /*background-color: pink;*/ /*opacity: 0.5;*/ top: -20px; left: -20px; } #box01 .qz{ width: 30px; height: 30px; border: 1px solid #C7C7C7; float: left; border-radius: 50%; margin: 5px; } #box01 .qz:hover{ background-color: pink; } #box02{ position: absolute; line-height: 546px; font-size: 50px; color: black; width: 100%; background-color: pink; display: none; opacity: 0.6; } </style>
script:
<script type="text/javascript"> window.onload = function () { let box = document.getElementById("box"); let box01 = document.getElementById("box01"); //画棋盘 let arr = new Array(); for (let i=0;i<13;i++){ arr[i] = new Array(); for (let j=0;j<13;j++){ arr[i][j] = document.createElement("div"); arr[i][j].className = "squre"; box.appendChild(arr[i][j]); } } //画棋子 let arr01 = new Array(); for (let i=0;i<14;i++){ arr01[i] = new Array(); for (let j=0;j<14;j++){ arr01[i][j] = document.createElement("div"); arr01[i][j].className = "qz"; box01.appendChild(arr01[i][j]); } } for (let m=0;m<14;m++){ for (let n=0;n<14;n++){ arr01[m][n].onclick = function () { //下棋之前统计一下黑白棋的个数,以便黑白交换下棋 let count = 0; for (let l = 0; l < 14; l++) { for (let k = 0; k < 14; k++){ if (arr01[l][k].style.backgroundColor != "") { count++; } } } // console.log(count); if (this.className == "qz" && count % 2 == 0 && this.style.backgroundColor == "") { //下棋 this.style.backgroundColor = "black"; //引入判断函数 // console.log(m,n); checkGame(m, n); } else if (this.className == "qz" && count % 2 != 0 && this.style.backgroundColor == "") { //下棋 this.style.backgroundColor = "white"; //引入判断函数 checkGame(m, n); } } } } //判断哪方输赢,四个方向(横向、纵向、左斜、右斜) //m是y轴,n是x轴 let a,b; let flag = 0; let box02 = document.getElementById("box02"); function checkGame(a,b) { //判断横向 let qzColor = arr01[a][b].style.backgroundColor; // console.log(qzColor); for (let k=(b-4);k<=(b+4);k++){ if (k>=0 && k < 14){ if (qzColor == arr01[a][k].style.backgroundColor && arr01[a][k].style.backgroundColor != ""){ flag++; if (flag == 5){ // alert(qzColor+" win!!"); box02.innerHTML = qzColor+" win!!"; box02.style.display = "block"; } } else { flag = 0; } } else { flag = 0; } } //判断纵向 for (let k=(a-4);k<=(a+4);k++){ if (k>=0 && k < 14){ if (qzColor == arr01[k][b].style.backgroundColor && arr01[k][b].style.backgroundColor != ""){ flag++; if (flag == 5){ // alert(qzColor+" win!!"); box02.innerHTML = qzColor+" win!!"; box02.style.display = "block"; } } else { flag = 0; } } else { flag = 0; } } //判断左斜 let ax = (a-4);//ax用来记录横坐标的变化 for (let k=(b-4);k<=(b+4);k++){ if (k>=0 && k < 14 && ax>=0 && ax<14){ if (qzColor == arr01[ax][k].style.backgroundColor && arr01[ax][k].style.backgroundColor != ""){ flag++; if (flag == 5){ // alert(qzColor+" win!!"); box02.innerHTML = qzColor+" win!!"; box02.style.display = "block"; } } else { flag = 0; } } else { flag = 0; } ax++; } //判断右斜 bx = a-4; for (let k=(b+4);k>=(b-4);k--){ if (k>=0 && k < 14 && bx>=0 && bx<14){ if (qzColor == arr01[bx][k].style.backgroundColor && arr01[bx][k].style.backgroundColor != ""){ flag++; if (flag == 5){ // alert(qzColor+" win!!"); box02.innerHTML = qzColor+" win!!"; box02.style.display = "block"; } } else { flag = 0; } } else { flag = 0; } bx++; } } } </script>
更多有趣的经典小游戏实现专题,分享给大家:
C++经典小游戏汇总
python经典小游戏汇总
python俄罗斯方块游戏集合
JavaScript经典游戏 玩不停
javascript经典小游戏汇总
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
华山资源网 Design By www.eoogi.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
华山资源网 Design By www.eoogi.com
暂无评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2024年09月21日
2024年09月21日
- [ABC]安娜-胆麦发烧女声[6N纯银镀膜][2016[低速原抓WAV+CUE]
- 任天堂今晚举行直面会!第三方及独立游戏展示
- 《哆啦A梦的铜锣烧店物语》发售!开罗公式+哆啦A梦
- 任天堂公布《塞尔达传说》系列时间线:野炊与王泪独立在外
- 五条人.2012-一些风景2CD【刀马旦】【WAV+CUE】
- 陈奕迅.2013-Easons.Life演唱会2CD(2024环球红馆40复刻系列)【环球】【WAV+CUE】
- 许美静.1995-遗憾(新马版)【上华】【WAV+CUE】
- 《叶倩文 歌声情缘》[WAV+CUE][410MB]
- 《张国荣 首首动听经典不容错过 追忆的风 2CD》[WAV+CUE][870MB]
- 《腾格尔 容中尔甲 亚东 高原三星 男人篇 3CD》[WAV/分轨][1GB]
- 命运圣契公测实测可用兑换码大全 命运圣契最新兑换码分享
- 黑神话悟空上品疾蝠精魄获取方法一览|上品疾蝠精魄收集攻略
- 《七龙珠电光炸裂!ZERO》GT角色预告片曝光,15位新角色登场
- [ABC]安娜-胆麦发烧女声[6N纯银镀膜][2016[低速原抓WAV+CUE]
- NewViennaOctetViennaWindSoloists-TheDeccaRecordings(2024)18CD[24-48][FLAC]-7