-
Notifications
You must be signed in to change notification settings - Fork 13.8k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Rewrite "rock paper scissors" project #26037
Merged
MaoShizhong
merged 23 commits into
TheOdinProject:main
from
cakegod:project_rock_paper_scissors
Apr 21, 2024
Merged
Changes from all commits
Commits
Show all changes
23 commits
Select commit
Hold shift + click to select a range
17c73c6
Improve clarity, wording and punctuation of the "rock paper scissors"…
cakegod c451481
Rewrite - first draft
cakegod cd96056
Merge branch 'main' into project_rock_paper_scissors
cakegod a96cbf2
Rewrite - second draft
cakegod 9e3ec9e
Merge branch 'main' into project_rock_paper_scissors
cakegod a173962
Changes from Manon draft v2 review
cakegod cb52cb7
Small refinements
cakegod b4f3b3f
Structure assignment section
cakegod fd861ba
Add math random hint
cakegod bb1e4c1
add hint for multi round playRound
cakegod 74d4fcf
Improve wording of most phrases
cakegod d565ca0
Apply suggestions from ravenco code review
cakegod 7b20b6c
Merge branch 'main' into project_rock_paper_scissors
cakegod b2b704e
fix markdown lint issues
cakegod 4f08dbc
add takina suggestion
cakegod df489e6
changes some phrases
cakegod 39b037b
Apply suggestions from code review
cakegod c0ab513
apply remaining suggestion
cakegod c4ab58d
Apply suggestions from code review
cakegod 5574e48
Apply remaining suggestions
cakegod e69a11d
add additional steps
cakegod 28dfc91
fix md linting issues
cakegod 3345fa1
fix mistakes
cakegod File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
108 changes: 82 additions & 26 deletions
108
foundations/javascript_basics/project_rock_paper_scissors.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,50 +1,106 @@ | ||
### Introduction | ||
|
||
We're going to make an implementation of grade-school classic "rock paper scissors". If you don't know what that is check the [Wikipedia article](https://en.wikipedia.org/wiki/Rock%E2%80%93paper%E2%80%93scissors) or [this](https://www.wikihow.com/Play-Rock,-Paper,-Scissors) detailed step-by-step. For the moment we're just going to play the game from the browser console, but **we will revisit this project in a later lesson and add a Graphical User Interface with buttons and text,** so don't forget to keep the code on GitHub! You might notice some 'Live Preview' links in the student solutions that have a GUI - this is coming in a later lesson. When you get there don't forget to come back and add your link! | ||
For this project, you will create the game [Rock Paper Scissors](https://www.wikihow.com/Play-Rock,-Paper,-Scissors). This game will be played entirely in the console. | ||
|
||
### Quick exercises before starting | ||
<div class="lesson-note"> | ||
|
||
1. Identify three ways to include JavaScript in a page. | ||
1. Test it out! Write `console.log("Hello World");` in JavaScript and check to see if it displays in the browser's console. | ||
Some of the student solutions below contain buttons, text, and other elements. These elements are part of what is called a graphical user interface (GUI). You'll create the GUI in a later lesson. In the meantime, remember to commit your code to GitHub. | ||
|
||
Finally, this is your first JavaScript program built from scratch, so don't forget the previous lesson on problem solving. Plan your solution out before writing any code, and test each piece as you build to ensure it is working before moving on to the next! | ||
</div> | ||
|
||
### Problem solving approach | ||
|
||
Since this is the first JavaScript project being built from scratch, it's important to remember the wise words from the [Problem Solving lesson](https://www.theodinproject.com/lessons/foundations-problem-solving). For each step in this project, be sure to do the following | ||
|
||
1. Plan or pseudocode your solution. | ||
1. Write the code. | ||
1. Test your code to make sure it works. | ||
|
||
### Assignment | ||
|
||
<div class="lesson-content__panel" markdown="1"> | ||
Don't forget to commit early & often! You can [reference the Commit Message lesson here](https://www.theodinproject.com/paths/foundations/courses/foundations/lessons/commit-messages)! | ||
|
||
1. Start a new Git repo for your project. | ||
1. Create a blank HTML document with a script tag (Hint: it is best practice to link an external .js file). This game is going to be played completely from the console, so don't worry about putting anything else in there. | ||
1. Your game is going to play against the computer, so begin with a function called `getComputerChoice` that will randomly return either 'Rock', 'Paper' or 'Scissors'. We'll use this function in the game to make the computer's play. *Tip: use the console to make sure this is returning the expected output before moving to the next step!* | ||
1. Write a function that plays a single round of Rock Paper Scissors. The function should take two parameters - the `playerSelection` and `computerSelection` - and then return a string that declares the winner or tie of the round like so: `"You Lose! Paper beats Rock"` | ||
Remember to commit early and often! To refresh your memory, check out the [commit messages lesson](https://www.theodinproject.com/paths/foundations/courses/foundations/lessons/commit-messages). | ||
|
||
#### Step 1: Setup the project structure | ||
|
||
1. Create a new Git repository for your project. | ||
1. Create a blank HTML document with a script tag. | ||
1. Check if the webpage includes JavaScript: | ||
- Write `console.log("Hello World")` in JavaScript. | ||
- Check if "Hello World" is logged in the browser console once you open your webpage. | ||
|
||
It's best practice to link to an external JavaScript file inside this script tag. Using an external JavaScript file keeps your HTML file clean and organized. | ||
|
||
You don't have to write additional code in the HTML file. This game is played entirely via the console. | ||
|
||
#### Step 2: Write the logic to get the computer choice | ||
|
||
Your game will be played against the computer. You will write a function that randomly returns "rock", "paper" or "scissors". | ||
|
||
1. Create a new function named `getComputerChoice`. | ||
1. Write the code so that `getComputerChoice` will randomly `return` one of the following string values: "rock", "paper" or "scissors". | ||
- **Hint**: The [Math.random](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Math/random) method returns a random number that's greater than or equal to 0 and less than 1. Think about how you can use this to conditionally return one of the multiple choices. | ||
cakegod marked this conversation as resolved.
Show resolved
Hide resolved
thatblindgeye marked this conversation as resolved.
Show resolved
Hide resolved
|
||
1. Test that your function returns what you expect using `console.log` or [the browser developer tools](https://www.theodinproject.com/lessons/foundations-javascript-developer-tools) before advancing to the next step. | ||
|
||
#### Step 3: Write the logic to get the human choice | ||
|
||
Your game will be played by a human player. You will write a function that takes the user choice returns it. | ||
|
||
- Make your function's playerSelection parameter case-insensitive (so users can input `rock`, `ROCK`, `RocK` or any other variation). | ||
1. Create a new function named `getHumanChoice`. | ||
1. Write the code so that `getHumanChoice` will return one of the valid choices depending on what the user inputs. | ||
- **Hint**: Use the [prompt](https://developer.mozilla.org/en-US/docs/Web/API/Window/prompt) method to get the user's input. | ||
1. Test what your function returns by using `console.log`. | ||
|
||
1. **Important note:** you want to `return` the results of this function call, *not* `console.log()` them. You're going to use what you `return` later on, so let's test this function by using console.log to see the results: | ||
#### Step 4: Declare the players score variables | ||
|
||
```javascript | ||
function playRound(playerSelection, computerSelection) { | ||
// your code here! | ||
} | ||
Your game will keep track of the players score. You will write variables to keep track of the players score. | ||
|
||
const playerSelection = "rock"; | ||
const computerSelection = getComputerChoice(); | ||
console.log(playRound(playerSelection, computerSelection)); | ||
``` | ||
1. Create two new variables named `humanScore` and `computerScore` in the global scope. | ||
1. Initialize those variables with the value of `0`. | ||
|
||
1. Write a NEW function called `playGame()`. Use the previous function *inside* of this one to play a five round game that keeps score and reports a winner or loser at the end. | ||
- You have not officially learned how to "loop" over code to repeat function calls... if you already know about loops from somewhere else (or if you feel like doing some more learning) feel free to use them. If not, don't worry! Just call your `playRound` function 5 times in a row. Loops are covered in the next lesson. | ||
- At this point you should be using `console.log()` to display the results of each round and the winner at the end. | ||
- Use `prompt()` to get input from the user. [Read the docs here if you need to.](https://developer.mozilla.org/en-US/docs/Web/API/Window/prompt) | ||
- Feel free to re-work your previous functions if you need to. Specifically, you might want to change the return value to something more useful. | ||
- Feel free to create more "helper" functions if you think it would be useful. | ||
#### Step 5: Write the logic to play a single round | ||
|
||
Your game will be played round by round. You will write a function that takes the human and computer player choices as arguments, plays a single round, increments the round winner's score and logs a winner announcement. | ||
|
||
1. Create a new function named `playRound`. | ||
1. Define two parameters for `playRound`: `humanChoice` and `computerChoice`. Use these two parameters to take the human and computer choices as arguments. | ||
1. Make your function's `humanSelection` parameter case-insensitive so that players can input "rock", "ROCK", "RocK", or other variations. | ||
1. Write the code for your `playRound` function to `console.log` a string value representing the round winner, such as: "You lose! Paper beats Rock". | ||
1. Increment the `humanScore` or `computerScore` variable based on the round winner. | ||
|
||
Example code: | ||
|
||
```javascript | ||
function playRound(humanChoice, computerChoice) { | ||
// your code here! | ||
} | ||
|
||
const humanSelection = getHumanChoice(); | ||
const computerSelection = getComputerChoice(); | ||
|
||
playRound(humanSelection, computerSelection); | ||
``` | ||
|
||
#### Step 6: Write the logic to play the entire game | ||
|
||
Your game will play 5 rounds. You will write a function named `playGame` that calls `playRound` to play 5 rounds, keeps track of the scores and declares a winner at the end. | ||
|
||
1. Create a new function named `playGame`. | ||
1. Move your `playRound` function and score variables so that they're declared inside of the new `playGame` function | ||
1. Play 5 rounds by calling `playRound` 5 times. | ||
- **Hint**: When you assign a function call to a variable, the return value of that function is assigned to the variable. Accessing the variable afterward will only provide the assigned value; it doesn't recall the function. You need to recall the choice functions to get new choices for each round. | ||
thatblindgeye marked this conversation as resolved.
Show resolved
Hide resolved
|
||
- Re-work your previous functions or create more helper functions if necessary. Specifically, you may want to change the return values to something more useful. | ||
- If you already know about loops, you can use them. If not, don't worry! Loops will be covered in the next lesson. | ||
|
||
</div> | ||
|
||
<div class="lesson-note" markdown="1"> | ||
|
||
When making interactive projects, like this one, you might be tempted to add more features, improve interactivity, user experience, design and styling of your website, and so on. | ||
|
||
We recommend not doing that, and saving this effort for your portfolio projects. | ||
|
||
For more information on learning mindset and portfolio pieces read [Part 5](https://dev.to/theodinproject/learning-code-f56) and [Part 7](https://dev.to/theodinproject/strategically-building-your-portfolio-1km4) of [Becoming a TOP Success Story](https://dev.to/theodinproject/becoming-a-top-success-story-mindset-3dp2) | ||
|
||
</div> |
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If this is meant to echo the problem solving lesson, we probably want these items to be about understanding the problem, planning, writing pseudo code, and then dividing and conquering, no?
Maybe it's the wording leading into it, though. "Before you start this project" could maybe be removed, then just say, "For each step in this project, be sure to do the following:"