Week 1 Assignment
Getting Started
- Fork this repository
- Clone the repository to your local computer.
- Install packages
npm install
- Ensure tests can be run. The test suite should fail initially, and the test suite runs both the lint and test commands.
npm test
- Use the following commands to test individual files and code correctness.
# lint the code npm run lint # run jest tests in watch mode (handy for updating the code and seeing test results in real time) npm run test:watch # run tests in CI mode (no watch mode, runs the test suite and exits immediately) npm test # run an individual file (handy if you're trying to test/experiment with a single file) npm run file -- ./src/timer/runTimer.js
Overview
-
The folder src/components contains a file called
HTMLElement.js
. In this file, create a module that meets the following requirements:- Create a class called
HTMLElement
. This class should have a constructor with two parameters: tag and content. Both of these parameters should be stored as instance variables within the class. Instance variables should have the same names as the parameters. - Once the HTMLElement class is created, add a function to the class called
render
that can be called publicly. This function should return the HTML element with the content provided. - Within
render
, use a template literal to render the element. - Example usage (you can see the tests for more examples):
const lovelaceQuote = new HTMLElement('p', 'I am never so happy as when I am really engaged in good earnest...'); console.log(lovelaveQuote.render()); // prints "<p>I am never so happy as when I am really engaged in good earnest...</p>"
- Create a class called
- Note that you'll need to change the
export default {}
line to export the class instead of an empty object literal.
-
The folder src/components contains a file called
DivElement.js
. In this file, create a module that meets the following requirements:- Create a class called
DivElement
that extends theHTMLElement
class created previously. You'll need to import the class made in step 1. - This class should have a constructor with one parameter:
content
. - This class should inherit the render function in the parent class (do not override it, aka define it in
DivElement
). - Within
render
, use a template literal to render the element. - Example usage:
const andIThinkToMyself = new DivElement('What a wonderful world'); console.log(andIThinkToMyself.render()); // prints "<div>What a wonderful world</div>"
- Create a class called
-
The folder src/timer contains two files called
Timer.js
andrunTimer.js
. Perform the following tasks:- Examine the code in these two files and determine each script's behavior.
- Refactor the code to use the ES6 class syntax.
- Refactor the code to use arrow function(s).
- Refactor the code to use
let/const
. - Refactor the code to avoid assigning
this
to a variable.
-
The folder src/rolodex contains two files called
people.json
androlodexPrinter.js
. Perform the following tasks:- Refactor the code to use template literals.
- Refactor the code to use object destructuring.
- Refactor the code to use array destructuring.
Submission
- In order for a valid submission, all tests must pass when running
npm test
. - In order for a valid submission, the linter should produce no errors (warnings are ok) when running
npm run lint
. - Create a pull request to this repository and ensure that the CI build succeeds.
Bonus
Each assignment will have a bonus section. Each bonus section is optional and provides an extra challenge if you choose to complete it. Completing the bonus section will not be checked and does not result in extra credit. It's mainly for your benefit!
- Complete some ES2015 Katas. These are similar to the homework, where you change code in order to have tests pass. You can also learn about other ECMAScript features that we won't cover in class. Recommended sections:
- Promises
- Arrays
- Class
- Destructuring
- Generators
- Object literals
- Strings/template strings
- Arrow functions
- Rest/spread operators