An online markdown blog and knowledge repository.
Use constructor functions and prototypes, or ES6 Classes to model data.
Constructor Functions and Prototypes help create templates that can be used to create instantiations of things that carry and manipulate data (Code201).
Classes are simpler, and enable a model that includes inheritance and better use of memory when creating and storing object instances (and their data).
Classes have attributes and behaviors.
ES6 sytax and best practices for creating Constructor Functions:
const
to define a Constructor Function.instance InstanceOf type
will output Boolean if Instance template is teh same.ES6 Classes make this easier.
Use keyword class
to define a Class specifically.
Pascal-case the class name.
Constructor Function used to initialize the Class instance.
Functions (with and without parameter lists) are bolted-on simply.
An example directly from the [CodeFellows Lecture on EF6 Classes]:
class Animal {
constructor(name, legs) {
this.name = name;
this.legs = legs;
}
walk() {
this.isWalking = true;
}
eat() {
this.isEating = true;
}
}
When using Classes, Prototype Methods are automatic.
In the previous example, walk()
and eat()
are actually Prototype Methods.
The 'extends' keyword tells JS to use the Class that follows as its 'parent' or 'base' class.
The newly created Class automatically acquires the attributes and behaviors of the 'extended class'.
class Dog extends Animal {
}
let rosie = new Dog('Rolph', 4);
rosie.walk();
rosie.eat();
console.log(rosie);
Extends does lots of work for you by 'inheriting' the attributes and behaviors of the 'parent class'.
Extends creates a 'child class'.
It is easier to speak english to walk through the code when using Class syntax rather than Constructor Function syntax and trying to meet all of its requirements.
Syntactic Sugar: The way code is written that (usually) makes the code easier to read, write, and speak.
For example: When pair programming, the navigator can just say:
"Create a new Class called Animal that has properties Name and Legs that can be assigned using parameters. Add functions Walk and Eat to the Animal..."
class Animal {
constructor(name, legs) {
this.name = name;
this.legs = legs;
}
walk() {
this.isWalking = true;
}
eat() {
this.isEating = true;
}
}
Continuing this example to inheritance:
"Now extend the Animal Class to create a child class named Dog. For now do not add any properties or methods."
class Dog extends Animal {
}
const Animal = function(name, legs) {
this.name = name;
this.legs = legs;
this.eat = function() {
this.isEating = true;
}
}
Animal.prototype.walk = function() {
this.isWalking = true;
}
const Dog = function(name, legs) {
Animal.call(this, name, legs);
}
Dog.prototype = Object.create(Animal.prototype);
let puppy = new Dog('blake', 4);
puppy.walk();
puppy.eat();
console.log(puppy);
console.log(puppy instanceof Animal);
console.log(puppy instanceof Dog);
class Animal {
constructor(name, legs) {
this.name = name;
this.legs = legs;
}
walk() {
this.isWalking = true;
}
eat() {
this.isEating = true;
}
}
class Dog extends Animal {
constructor(name, legs, furType) {
super(name,legs);
this.furType = furType;
}
speak() {
console.log('Wooof!');
}
}
let rosie = new Dog('rosie', 4, 'Short Hair');
rosie.walk();
rosie.eat();
console.log(rosie);
rosie.speak();
Submit this link to complete the Assignment:
Jon's completed ES6 Classes Replit
Back to ReadMe