7.16 LAB: JavaScript Tic-Tac-Toe
In this lab, you will write JavaScript to implement a Tic-Tac-Toe game, as shown below. The human is X, and the computer is O. A "New game" button starts a new game.
Investigate the page elements
The given index.html file contains all needed page elements for a game of Tic-Tac-Toe:
- A div with ID gameBoard and 9 buttons forms the game board. CSS in tictactoe.css converts the div and buttons into a 3x3 grid.
- A paragraph with ID turnInfo, initially containing text "TURN INFO", indicates the turn is the player's or computer's.
- A "New game" button with ID newGameButton allows the player to clear the board and start a new game.
Investigate the stylesheet
The given tictactoe.css file contains .x and .o rules to set the X and O button colors. Other CSS rules style the grid and buttons.
Investigate the JavaScript
The given tictactoe.js script has six declarations:
- playerTurn: Boolean variable that is true when the turn belongs to the player and false when the turn belongs to the computer.
- computerMoveTimeout: ID of an active timeout for the computer's move, or 0 if no such timeout exists.
- gameStatus: Object that contains four possible game statuses. The checkForWinner() function returns the appropriate game status.
- domLoaded(): Function that is called when the DOM loads to start the game. Events for the "New game" button click and game board button clicks are registered. Then newGame() is called to start the game. The domLoaded() function is implemented for you and requires no alteration.
- getGameBoardButtons(): Function that returns an array of the 9 <button> elements from the game board. The first 3 elements are the top row, the next 3 the middle row, and the last 3 are the bottom row. The getGameBoard() function is implemented for you and requires no alteration.
- checkForWinner(): Function that returns a gameStatus value indicating if the human has won, if the computer has won, if a draw occurs, or if more moves are available.
Implement newGame()
Implement the newGame() function to do the following:
- Use clearTimeout() to clear the computer's move timeout and then set computerMoveTimeout back to 0.
- Loop through all game board buttons and set the inner HTML of each to an empty string. Also remove the class name and disabled attribute. The disabled attribute prevents the user from clicking the button, but all the buttons should be clickable when starting a new game.
- Allow the player to take a turn by setting playerTurn to true.
- Set the text of the turn information paragraph to "Your turn".
Implement boardButtonClicked()
Implement the boardButtonClicked() function to do the following:
- If playerTurn is true:
- Set the button's inner HTML to "X".
- Add the "x" class to the button.
- Set the button's disabled attribute to true so the button cannot be clicked again.
- Call switchTurn() so the computer can take a turn.
Implement switchTurn()
Implement the switchTurn() function to do the following:
- Call checkForWinner() to determine the game's status.
- If more moves are left, do the following:
- If switching from the player's turn to the computer's turn, use setTimeout() to call makeComputerMove() after 1 second (1000 milliseconds). Assign the return value of setTimeout() to computerMoveTimeout. The timeout simulates the computer "thinking", and prevents the nearly-instant response to each player move that would occur from a direct call to makeComputerMove().
- Toggle playerTurn's value from false to true or from true to false.
- Set the turn information paragraph's text content to "Your turn" if playerTurn is true, or "Computer's turn" if playerTurn is false.
- In the case of a winner or a draw game, do the following:
- Set playerTurn to false to prevent the user from being able to place an X after the game is over.
- If the human has won, display the text "You win!" in the turn info paragraph.
- If the computer has won, display the text "Computer wins!" in the turn info paragraph.
- If the game is a draw, display the text "Draw game" in the turn info paragraph.
Implement makeComputerMove()
Implement the makeComputerMove() function to do the following:
- Choose a random, available button, and set the button's inner HTML to "O".
- Add the "o" class to the button.
- Set the button's disabled attribute to true.
- Call switchTurn() at the end of the function to switch back to the player's turn.
Trending nowThis is a popular solution!
Step by stepSolved in 2 steps with 2 images
- Bean Counter - Chapter 18 - Use your TEXT editor to build the Bean Counter program - Save each version (Versions 0 - 10) - Final Version should work! Start with this code for VERSION O in your text editor! Save as BeanV0.html charset="UTF-8"> The Bean Counter Confirming that bean.html works var drink = "latte"; var ounce = 12; var shots = 2; var taxRate = 0.088; var price; if (drink == "espresso") price = 1.40; if (drink if (ounce :== "latte" || drink == "cappuccino") { 8) price = 1.95; if (ounce == 12) price = 2.35; if (ounce == 16) price = 2.75; } if (drink == "Americano") price = 1.20 + 0.30*(ounce/8); "expresso") price = price + (shots - 1)*.50; if (drink == price = price + price*taxRate; alert(price); html>arrow_forward4.28 LAB: Temperature converter In this lab, you will implement a temperature converter in JavaScript. The user may type a temperature in either the Celsius or Fahrenheit textbox and press Convert to convert the temperature. An image displays based on the converted temperature. Download the ZIP file below containing HTML, JavaScript, and image files. The HTML file declares five UI elements: Element's ID Element description cInput Text input field for Celsius temperature fInput Text input field for Fahrenheit temperature convertButton Button that, when clicked, converts from one temperature to the other errorMessage Paragraph for displaying an error message when temperature cannot be converted weatherImage Image corresponding to the temperature Implement conversion functions (2 points) Implement the convertCtoF() and convertFtoC() functions to convert between Celsius and Fahrenheit. convertCtoF() takes a single numerical argument for a temperature in Celsius and…arrow_forwardCHALLENGE ACTIVITY 5.10.2: Simon says. "Simon Says" is a memory game where "Simon" outputs a sequence of 10 characters (R, G, B, Y) and the user must repeat the sequence. Create a for loop that compares each character of the two strings. For each matching character, add one point to user_score. Upon a mismatch, end the loop.Sample output with inputs: 'RRGBRYYBGY' 'RRGBBRYBGY' User score: 4 Use Python, please.arrow_forward
- 2. Sketch the blocks for an app with a single button that, when clicked, sends a text "thinking about you" to one of the phone numbers 111-1111, 222-2222, and 333-3333 randomly. initialize global phoneList to make a list 111-1111 select list item İst Index 222-2222 333-3338 random integer from toarrow_forward9- Fully explain the following code. what is the output of the following code (draw a picture to show the output of the code) .descendants * { display: block; border: 2px solid lightgrey; color: lightgrey: padding: 5px; margin: 15px; } $(document).ready(function(){ $("div").find("*").css({"color": "red", "border": "2px solid red"}); }); div (current element) p (child) span (grandchild) p (child) span (grandchild)arrow_forward
- Computer Networking: A Top-Down Approach (7th Edi...Computer EngineeringISBN:9780133594140Author:James Kurose, Keith RossPublisher:PEARSONComputer Organization and Design MIPS Edition, Fi...Computer EngineeringISBN:9780124077263Author:David A. Patterson, John L. HennessyPublisher:Elsevier ScienceNetwork+ Guide to Networks (MindTap Course List)Computer EngineeringISBN:9781337569330Author:Jill West, Tamara Dean, Jean AndrewsPublisher:Cengage Learning
- Concepts of Database ManagementComputer EngineeringISBN:9781337093422Author:Joy L. Starks, Philip J. Pratt, Mary Z. LastPublisher:Cengage LearningPrelude to ProgrammingComputer EngineeringISBN:9780133750423Author:VENIT, StewartPublisher:Pearson EducationSc Business Data Communications and Networking, T...Computer EngineeringISBN:9781119368830Author:FITZGERALDPublisher:WILEY