-
Notifications
You must be signed in to change notification settings - Fork 0
/
script.js
95 lines (81 loc) · 2.54 KB
/
script.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
var origBoard;
const huPlayer = '0';
const aiPlayer = 'X';
const winCombos = [
[0,1,2],
[3,4,5],
[6,7,8],
[0,3,6],
[1,4,7],
[2,5,8],
[0,4,8],
[6,4,2]
];// These are the winning combinations. Each square has a unique id (0-8)
const cells = document.querySelectorAll('.cell');
startGame();
function startGame() {
document.querySelector(".endGame").style.display ="none";
origBoard = Array.from(Array(9).keys());
for(var i=0; i<cells.length; i++){
cells[i].innerText = '';
cells[i].style.removeProperty('background-color');
cells[i].addEventListener('click', turnClick, false);
document.getElementById(i).style.cursor = "pointer";
}
}
function turnClick(square){
if(typeof origBoard[square.target.id] == 'number'){
turn(square.target.id, huPlayer)
if(!checkTie()) turn(bestSpot(), aiPlayer);
}
}
function turn(squareId, player){
origBoard[squareId] = player;
document.getElementById(squareId).innerText = player;
let gameWon = checkWin(origBoard, player)
if (gameWon) gameOver(gameWon)
}
function checkWin(board, player){
let plays = board.reduce((a,e,i) =>
(e === player) ? a.concat(i) : a,[]);
let gameWon = null;
for (let [index, win] of winCombos.entries()){
if (win.every(elem => plays.indexOf(elem) > -1)){
gameWon = {index: index, player: player};
break;
}
}
return gameWon;
}
function gameOver(gameWon){
for (let index of winCombos[gameWon.index]) {
document.getElementById(index).style.backgroundColor =
gameWon.player == huPlayer ? "blue" : "red";
}
for (var i =0; i < cells.length; i++ ){
cells[i].removeEventListener('click', turnClick, false);
document.getElementById(i).style.cursor = "auto";
}
declareWinner(gameWon.player == huPlayer ? "You Win!":"You lose!");
}
function declareWinner(who){
document.querySelector(".endGame").style.display = "block";
document.querySelector(".endGame .text").innerText = who;
}
function emptySquares(){
return origBoard.filter(s => typeof s == 'number');
}
function bestSpot(){
return emptySquares()[0];
}
function checkTie(){
if(emptySquares().length == 0 && declareWinner(gameWon.player == !huPlayer)){
for(var i =0; i, cells.length; i++){
cells[i].style.backgroundColor = "green";
cells[i].removeEventListener('click', turnClick, false);
}
declareWinner("Tie Game!");
return true;
}
return false;
}