首页 前端知识 html五子棋游戏(附源码),近期想跳槽的程序员必看

html五子棋游戏(附源码),近期想跳槽的程序员必看

2024-04-29 11:04:53 前端知识 前端哥 786 6 我要收藏

// 我,悔棋

chressBord[_nowi][_nowj] = 0; //我,已占位置 还原

minusStep(_nowi, _nowj); //销毁棋子

for(var k = 0; k < count; k++){ // 将可能赢的情况都减1

if(wins[_nowi][_nowj][k]){

myWin[k]–;

computerWin[k] = _compWin[k];//这个位置对方可能赢

}

}

// 计算机相应的悔棋

chressBord[_compi][_compj] = 0; //计算机,已占位置 还原

minusStep(_compi, _compj); //销毁棋子

for(var k = 0; k < count; k++){ // 将可能赢的情况都减1

if(wins[_compi][_compj][k]){

computerWin[k]–;

myWin[k] = _myWin[i];//这个位置对方可能赢

}

}

resultTxt.innerHTML = ‘–益智五子棋–’;

returnAble = true;

backAble = false;

}

// 撤销悔棋

returnbtn.onclick = function(e){

if(!returnAble) { return; }

// 我,撤销悔棋

chressBord[_nowi][_nowj] = 1; //我,已占位置

oneStep(_nowi,_nowj,me);

for(var k = 0; k < count; k++){

if(wins[_nowi][_nowj][k]){

myWin[k]++;

_compWin[k] = computerWin[k];

computerWin[k] = 6;//这个位置对方不可能赢

}

if(myWin[k] == 5){

resultTxt.innerHTML = ‘恭喜,你赢了!’;

over = true;

}

}

// 计算机撤销相应的悔棋

chressBord[_compi][_compj] = 2; //计算机,已占位置

oneStep(_compi,_compj,false);

for(var k = 0; k < count; k++){ // 将可能赢的情况都减1

if(wins[_compi][_compj][k]){

computerWin[k]++;

_myWin[k] = myWin[k];

myWin[k] = 6;//这个位置对方不可能赢

}

if(computerWin[k] == 5){

resultTxt.innerHTML = ‘o(╯□╰)o,计算机赢了,继续加油哦!’;

over = true;

}

}

returnbtn.className += ’ '+ ‘unable’;

returnAble = false;

backAble = true;

}

// 计算机下棋

var computerAI = function (){

var myScore = [];

var computerScore = [];

var max = 0;

var u = 0, v = 0;

for(var i = 0; i < 15; i++){

myScore[i] = [];

computerScore[i] = [];

for(var j = 0; j < 15; j++){

myScore[i][j] = 0;

computerScore[i][j] = 0;

}

}

for(var i = 0; i < 15; i++){

for(var j = 0; j < 15; j++){

if(chressBord[i][j] == 0){

for(var k = 0; k < count; k++){

if(wins[i][j][k]){

if(myWin[k] == 1){

myScore[i][j] += 200;

}else if(myWin[k] == 2){

myScore[i][j] += 400;

}else if(myWin[k] == 3){

myScore[i][j] += 2000;

}else if(myWin[k] == 4){

myScore[i][j] += 10000;

}

if(computerWin[k] == 1){

computerScore[i][j] += 220;

}else if(computerWin[k] == 2){

computerScore[i][j] += 420;

}else if(computerWin[k] == 3){

computerScore[i][j] += 2100;

}else if(computerWin[k] == 4){

computerScore[i][j] += 20000;

}

}

}

if(myScore[i][j] > max){

max = myScore[i][j];

u = i;

v = j;

}else if(myScore[i][j] == max){

if(computerScore[i][j] > computerScore[u][v]){

u = i;

v = j;

}

}

if(computerScore[i][j] > max){

max = computerScore[i][j];

u = i;

v = j;

}else if(computerScore[i][j] == max){

if(myScore[i][j] > myScore[u][v]){

u = i;

v = j;

}

}

}

}

}

_compi = u;

_compj = v;

oneStep(u,v,false);

chressBord[u][v] = 2; //计算机占据位置

for(var k = 0; k < count; k++){

if(wins[u][v][k]){

computerWin[k]++;

_myWin[k] = myWin[k];

myWin[k] = 6;//这个位置对方不可能赢了

if(computerWin[k] == 5){

resultTxt.innerHTML = ‘o(╯□╰)o,计算机赢了,继续加油哦!’;

over = true;

}

}

}

if(!over){

me = !me;

}

backAble = true;

returnAble = false;

var hasClass = new RegExp(‘unable’).test(’ ’ + returnbtn.className + ’ ');

if(!hasClass) {

returnbtn.className += ’ ’ + ‘unable’;

}

}

//绘画棋盘

var drawChessBoard = function() {

for(var i = 0; i < 15; i++){

context.moveTo(15 + i * 30 , 15);

context.lineTo(15 + i * 30 , 435);

context.stroke();

context.moveTo(15 , 15 + i * 30);

context.lineTo(435 , 15 + i * 30);

context.stroke();

}

}

//画棋子

var oneStep = function(i,j,me) {

context.beginPath();

context.arc(15 + i * 30, 15 + j * 30, 13, 0, 2 * Math.PI);// 画圆

context.closePath();

//渐变

var gradient = context.createRadialGradient(15 + i * 30 + 2, 15 + j * 30 - 2, 13, 15 + i * 30 + 2, 15 + j * 30 - 2, 0);

if(me){

gradient.addColorStop(0,‘#0a0a0a’);

gradient.addColorStop(1,‘#636766’);

}else{

gradient.addColorStop(0,‘#d1d1d1’);

gradient.addColorStop(1,‘#f9f9f9’);

}

context.fillStyle = gradient;

context.fill();

}

//销毁棋子

var minusStep = function(i,j) {

//擦除该圆

context.clearRect((i) * 30, (j) * 30, 30, 30);

// 重画该圆周围的格子

context.beginPath();

context.moveTo(15+i30 , j30);

context.lineTo(15+i30 , j30 + 30);

context.moveTo(i30, j30+15);

context.lineTo((i+1)30 , j30+15);

context.stroke();

}

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注前端)
img

最后

推荐一些系统学习的途径和方法。

路线图

每个Web开发人员必备,很权威很齐全的Web开发文档。作为学习辞典使用,可以查询到每个概念、方法、属性的详细解释,注意使用英文关键字搜索。里面的一些 HTML,CSS,HTTP 技术教程也相当不错。

CodeChina开源项目:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

HTML 和 CSS:

html5知识

css基础知识

csdnimg.cn/img_convert/abffda3a0cfe5b9baa70f132ab55f248.png)

每个Web开发人员必备,很权威很齐全的Web开发文档。作为学习辞典使用,可以查询到每个概念、方法、属性的详细解释,注意使用英文关键字搜索。里面的一些 HTML,CSS,HTTP 技术教程也相当不错。

CodeChina开源项目:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

HTML 和 CSS:

html5知识

css基础知识

转载请注明出处或者链接地址:https://www.qianduange.cn//article/6231.html
评论
发布的文章

@JsonCreator和@JsonValue

2024-05-05 22:05:05

Python 字符串转换为 JSON

2024-05-05 22:05:00

大家推荐的文章
会员中心 联系我 留言建议 回顶部
复制成功!