Appendix B: Practice, Practice, Practice!
In this appendix, we'll explore some exercises and their suggested solutions. These are just to get you started with practice over the concepts from the book.
Practicing Comparisons
Let's practice working with value types and comparisons (Chapter 4, Pillar 3) where coercion will need to be involved.
scheduleMeeting(..)
should take a start time (in 24-hour format as a string "hh:mm") and a meeting duration (number of minutes). It should return true
if the meeting falls entirely within the work day (according to the times specified in dayStart
and dayEnd
); return false
if the meeting violates the work day bounds.
Try to solve this yourself first. Consider the usage of equality and relational comparison operators, and how coercion impacts this code. Once you have code that works, compare your solution(s) to the code in "Suggested Solutions" at the end of this appendix.
Practicing Closure
Now let's practice with closure (Chapter 4, Pillar 1).
The range(..)
function takes a number as its first argument, representing the first number in a desired range of numbers. The second argument is also a number representing the end of the desired range (inclusive). If the second argument is omitted, then another function should be returned that expects that argument.
Try to solve this yourself first.
Once you have code that works, compare your solution(s) to the code in "Suggested Solutions" at the end of this appendix.
Practicing Prototypes
Finally, let's work on this
and objects linked via prototype (Chapter 4, Pillar 2).
Define a slot machine with three reels that can individually spin()
, and then display()
the current contents of all the reels.
The basic behavior of a single reel is defined in the reel
object below. But the slot machine needs individual reels—objects that delegate to reel
, and which each have a position
property.
A reel only knows how to display()
its current slot symbol, but a slot machine typically shows three symbols per reel: the current slot (position
), one slot above (position - 1
), and one slot below (position + 1
). So displaying the slot machine should end up displaying a 3 x 3 grid of slot symbols.
Try to solve this yourself first.
Hints:
Use the
%
modulo operator for wrappingposition
as you access symbols circularly around a reel.Use
Object.create(..)
to create an object and prototype-link it to another object. Once linked, delegation allows the objects to sharethis
context during method invocation.Instead of modifying the reel object directly to show each of the three positions, you can use another temporary object (
Object.create(..)
again) with its ownposition
, to delegate from.
Once you have code that works, compare your solution(s) to the code in "Suggested Solutions" at the end of this appendix.
Suggested Solutions
Keep in mind that these suggested solutions are just that: suggestions. There's many different ways to solve these practice exercises. Compare your approach to what you see here, and consider the pros and cons of each.
Suggested solution for "Comparisons" (Pillar 3) practice:
Suggested solution for "Closure" (Pillar 1) practice:
Suggested solution for "Prototypes" (Pillar 2) practice:
That's it for this book. But now it's time to look for real projects to practice these ideas on. Just keep coding, because that's the best way to learn!
Original Source
You can read original author source from here