-
Notifications
You must be signed in to change notification settings - Fork 62
/
Copy path18_object_prototype.js
120 lines (99 loc) · 2.95 KB
/
18_object_prototype.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
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
/**
* Javascript is about Object !
*
* Apa itu prototype object?
*
* Jadi setiap kali kita buat Function(), Javascript sudah siapkan
* object prototype didalamnya.
*/
function Person() {
}
/**
* fungsi Person() klo kita cek di console, maka dia sudah nyediain object
* yang diberi nama prototype
*
* Person.prototype = {}
*
* coba aja cek dengan : console.log(Person)
*
* prototype berguna untuk membuat properties dan juga inheritance
*/
function Person() {
this.name = "Budi"
//membuat method dalam Fucntion constructor is a bad idea
//karena kita sbnarnya assign anonim funcrion ke memory
// setiap kali ada instanisasi dengan keyword new Person()
//makanya lebih baik buat method itu di prottype saja
this.sayName = function() {
return 'My name is ' + this.name;
};
}
/**
* Bisa juga kita buat begini
*/
Person.prototype.name = "Budi";
/**
* Bisa juga untuk membuat method baru
*/
Person.prototype.sayName = function() {
return 'My name is ' + this.name;
};
Person.prototype.newMethod = function() {
//
};
Person.prototype.newMethodAgain = function() {
//
};
/**
* Semua function yang kita buat, itu sebenarnya mewarisi prototype dari Object(),
* sebuah built-in function di Javascript
*
* Misal kita buat
*/
function Human () {
}
/**
* Human sebenarnya mewarisi function Object(), makanya kalo kita buat:
*/
var agus = new Human();
/**
* agus akan punya akses ke properti prototype milik function Object()
*
* misal: agus.valueOf(), agus.hasOwnProperty(), agus.isPrototypeOf() dan lain-lain
* silahkan cek di console browser
*
* Jika dirunut maka urutan inheritance nya:
*
* agus -> inherit from -> Human() -> inherit from -> Object()
* atau lebih detail lagi
* agus -> inherit from -> Human.prototype -> inherit from -> Object.prototype
*
* tapi si agus tidak punya akses langsung ke property dari constructor Object()
*
* agus.create() <--- error , karenanya kalo kita check
* agus.hasOwnProperty('create') <-- false
*/
/**
* Prototype dari Class parent akan diwariskan ke property __proto__ dari Child
*
* secara teknis ditulis: child.__proto__ = parent.prototype
*/
function Animal(name) {
this.name = name;
}
Animal.prototype.sayName = function() {
console.log('Saya ' + this.name)
};
var kambing = new Animal('Kambing');
/**
* kode diatas kita bisa ambil faidah sbb:
*
* 1. Animal adalah sebuah function, maka __proto__ dari Animal adalah prototype dari Function()
* - secara teknis ditulis: Animal.__proto__ = Function.prototype
* - cara cek nya: console.dir(Animal.__proto__)
*
* 2. kambing adalah salah satu jenis (instance dari) Animal, maka __proto__ dari kambing adalah
* prototype dari Animal()
* - secara teknis ditulis: kambing.__proto__ = Animal.prototype
* - cara cek nya: console.dir(kambing.__proto__)
*/