Understanding JavaScript Prototypes - Workshop
Mission
The goal of this workshop is to help you understand the object model in Javascript by learning how prototypes work.
Most guides / tutorials start explaining JavaScript objects by going directly to ‘constructor functions’, this workshop is different, it starts simple by explaining prototype chains and building from there.
Please read the exercises thoroughly and follow all conditions, they are there to help you learn!
What you will learn
- What are prototypes chains
- Message delegation in a prototype chain
- What are function constructors
- What are function prototypes and how to work with them
Installation & Update
$ npm install -g planetproto@latest
Some npm installations require use of sudo
in the above command. Recommend to instead reinstall node/npm so you don't need sudo.
Usage Instructions
1. Selecting a problem to work on
Once the workshop is installed, run planetproto
to print a menu
where you can select a problem to work on.
$ planetproto
Problems are listed in rough order of difficulty. You are advised to complete them in order, as later problems will build on skills developed by solving previous problems.
2. Writing your solution
Once you have selected a problem, the workshop will remember which problem you are working on. Using your preferred editor, simply create a file to write your solution in. Most problems will supply some boilerplate with which to get started.
Many challenges will ask you to make a 'claim'. We have provided claim
as a global function.
To make a claim write claim(actual, expected)
, e.g.:
;
3. Verifying your solution
Your solution will be verified against the output of the 'official' solution. If all of the output matches, then you have successfully solved the problem!
$ planetproto verify mysolution.js
Stuck?
Feedback and criticism is welcome, please log your troubles in issues.
Development
Run node planetproto.js
to run the workshop
Run node planetproto.js verify 010.js
to verify a submission
Thanks rvagg
This tutorial was built using rvagg's workshopper framework.
Licence
MIT
Robot designed by Ricardo Moreira from the Noun Project