The module challenge is the afternoon project or assignment that students work through independently. This expands on the guided project completed earlier with the instructor.
- Explain function scope
- Describe what closure is, how closure is created in a program and why it is important to understand closures in JavaScript
This challenge focuses on both scope and closures.
In this challenge you will be working to build a scoreboard
(in the console) that takes randomly generated data and keeps track of a game's progress. If you're not familiar with the rules of baseball what you need to know is this: there are 9 innings and teams take turns "at-bat." Teams can only score while they are at bat. A team stops being at bat once they have gotten 3 outs
by either striking out or through game play. You can read more about baseball rules here.
A scoreboard in a major league stadium looks something like this. In fact, the scoreboard at Fenway Park in Boston is actually quite famous.
There are layers upon layers of nested functions within the game of baseball. Your challenge today will be to work through tasks associated with these layers, and ultimately to produce a scoreboard that logs in the console.
- Fork repo and add TL as collaborator on Github
- Clone your fork (not Lambda's repo by mistake!)
cd
into your newly cloned repository- Create a new branch by typing
git checkout -b <firstName-lastName>
- Work on your branch, push commits and create PR as usual
Find the file index.js
and complete the tasks.
Edit the ReadMe
file with your answers.
- In your own words, define closure (1-2 sentences).
- Study the following code, then answer the questions below.
function personalDice(name){
return function(){
// generate random number between 1 and 6
const newRoll = Math.floor(Math.random() * 6);
console.log(`${name} rolled a ${newRoll}`)
}
}
const dansRoll = personalDice("Dan");
const zoesRoll = personalDice("Zoe");
dansRoll();
dansRoll();
a. Where is closure used in this code? How can you tell?
b. Compare and contrast calling dansRoll
the first and second time. What is always the same? What could change?
c. What is the lexical scope of newRoll
?
Once you begin, you will have 15 minutes to answer the questions here.
The completion of these questions is mandatory for MVP. However, passing the quiz doesn't affect your standing as a Lambda School student whatsoever. This is Lambda School testing itself! Please answer honestly and to the best of your ability without using external references.
After you have completed the requirements, create a new file called stretch.js
and practice more with closures. There are no tests for these problems.
See if you can complete one or more of the following challenges:
- Predict the output of the code below and explain why this is the output using what you learned today. When you're ready for answers, view an explanation [here](https://www.coderbyte.com/algorithm/3-common-javascript-closure-questions
(function(){
var a = b = 3;
})();
console.log("a defined? " + (typeof a !== 'undefined'));
console.log("b defined? " + (typeof b !== 'undefined'));
- Write a function that would allow you to do this using a closure. (This is another interview question we've seen before - when you're ready for answers, view an explanation here).
var addSix = createBase(6);
addSix(10); // returns 16
addSix(21); // returns 27
- Research the differences between functional programming and object oriented programming. Then, describe the pros and cons of functional programming vs object-oriented programming. This is a common interview question and great practice!
🧠 "I never Understood Closures" Blog
Follow these steps for completing your project.
- Submit a pull request to merge Branch into master (student's Repo). Please don't merge your own pull request
- Add your Team Lead as a reviewer on the pull request
- Your Team Lead will count the project as complete by merging the branch back into master