forked from OleksiyRudenko/a-tiny-JS-world
-
Notifications
You must be signed in to change notification settings - Fork 0
/
index.js
90 lines (73 loc) · 2.43 KB
/
index.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
/* Refer to https://github.com/OleksiyRudenko/a-tiny-JS-world for the task details
Complete the below for code reviewers' convenience:
Code repository: _put repo URL here_
Web app: _put project's github pages URL here_
*/
// ======== OBJECTS DEFINITIONS ========
// Define your objects here
class Inhabitant {
constructor(species, name, legs, gender, talk) {
this. species = species;
this.name = name;
this. legs = legs;
this.gender = gender;
this.talk = talk;
}
inhabitantDescr() {
return ['species', 'name', 'gender', 'legs', 'talk']
.map(property => this[property])
.join("; ");
}
}
class Dog extends Inhabitant {
constructor (name, gender) {
super('dog', name, 4, gender, 'woof!');
}
}
class Cat extends Inhabitant {
constructor(name, gender) {
super('cat', name, 4, gender, 'meow!');
}
}
class Catwoman extends Cat {
constructor(name, gender) {
super(name, gender);
this.species = 'catwoman';
this.legs = 2;
this.hands = 2;
}
inhabitantDescr() {
return `${super.inhabitantDescr()}; ${this.hands}`;
}
}
class Human extends Inhabitant {
constructor(name, gender, talk,) {
super('human', name, 2, gender, talk);
this.hands = 2;
}
inhabitantDescr() {
return `${super.inhabitantDescr()}; ${this.hands}`;
}
}
const dog = new Dog('Bim', 'male');
const cat = new Cat('Tom', 'male');
const man = new Human('Jack', 'male', 'Captain Jack Sparrow!');
const woman = new Human('Elizabeth', 'female', 'He is a Pirate.');
const catwoman = new Catwoman('Lisa', 'female');
const inhabitants = [dog, cat, man, woman, catwoman];
inhabitants.forEach((resident) => print(resident.inhabitantDescr()));
// ======== OUTPUT ========
/* Use print(message) for output.
Default tag for message is <pre>. Use print(message,'div') to change containing element tag.
Message can contain HTML markup. You may also tweak index.html and/or styles.css.
However, please, REFRAIN from improving visuals at least until your code is reviewed
so code reviewers might focus on a single file that is index.js.
*/
/* Print examples:
print('ABC');
print('<strong>ABC</strong>');
print('<strong>ABC</strong>', 'div');
print('human; John; male; 2; 2; Hello world!; Rex, Tom, Jenny');
print('human; <strong>John</strong>; male; 2; 2; <em>Hello world!</em>; Rex, Tom, Jenny');
print('human; <strong>John</strong>; male; 2; 2; <em>Hello world!</em>; Rex, Tom, Jenny', 'div');
*/