Skip to content

Latest commit

 

History

History
65 lines (45 loc) · 3.44 KB

README.md

File metadata and controls

65 lines (45 loc) · 3.44 KB

Deployment Link

https://efrainad.github.io/Tic-Tac-Toe/

Tic-Tac-Toe

Tic-Tac-Toe game for weekend HW 1 project on week 1, now been redone.

Overcomeing Challenge

When displaying multiple error messages: Switching from display: none to Display block too fast made it to where the animation wouldn't work. I found nothing online to tell me why I had this problem, and had to add another setTimeout to get around it. (It displayed just fine, without the animation though.)

I made a board display with gap feature, but sometimes one gab was larger then the othere, so I had to let this idea go, and change the boarders with a function to customize it by where it was in the "line up".

Because the AI had to track the "successful" move, then see if it quilityfied as a win, and it had to wait to process everything first to know, and keep the best one, this got a little trickly, and messey to keep track of. Was a good experince to try and work this out.

General Assembly Logo

Tic Tac Toe

Objectives

  • Build a tic tac toe game in HTML, CSS, and vanilla JavaScript
  • Use best practices when writing code

This week we have been learning about writing functions, working with loops, and writing conditionals. We also learned about HTML, CSS, and the DOM.

We will be making a Tic Tac Toe game using all of these concepts.

Getting Started

  • Before you even start working with JavaScript, construct the gameboard. The gameboard page should include the 3x3 grid (of divs), and at minimum a reset button. Using id and/or class on clickable elements will help you wire this up in JavaScript afterwards.
  • The JavaScript portion will be next
    • Select elements and attach functions via event listeners
    • You will also need a variable to keep track of moves. This will be used to indicate whether or not to draw an X or an O

Requirements

  • A user should be able to click on different squares to make a move.
  • Every click will alternate between marking an X and O
  • Upon marking of an individual cell, use JavaScript to add an X or O to the cell, according to whose turn it is.
  • A cell should not be able to be replayed once marked.
  • You should not be able to click remaining empty cells after the game is over.
  • Add a reset button that will clear the contents of the board.
  • Display a message to indicate which turn is about to be played.
  • Detect draw conditions (ties/cat's game)
  • Detect winner: Stop game and declare the winner if one player ends up getting three in a row.
    • Hint: Determine a set of winning combinations. Check those combinations on the board contents after every move.

Have Fun - The best way to learn is by playing with code. Let creativity guide you and try some experiments with JS and CSS and see what you can do.

Bonuses

  • Implement your reset button without refreshing the whole page
  • Track player's wins over time
  • Add a simple AI to support one player vs computer mode. In this case, "simple" just means having the computer pick a random empty square.
  • Make your computer seem more human by adding a short time delay between your turn and the computer's turn.
  • Style it up! Get creative, or even make a theme!

Super Duper Bonus

  • Add an AI that can beat you every time with the mini-max algorithm.

Licensing

  1. All content is licensed under a CC-BY-NC-SA 4.0 license.
  2. All software code is licensed under GNU GPLv3. For commercial use or alternative licensing, please contact [email protected].