官术网_书友最值得收藏!

Classes

I am a guy who believes that JavaScript is an object-based programming language and not an object-oriented programming language, and I know quite a lot of people who disagree with me.

In vanilla JavaScript, we have functions, which act like a class and exhibit prototype-based inheritance. In TypeScript/ES6, we have the class construct:

class Person { 
name: string;

constructor(personName: string) {
this.name = personName;
}

getName {
return "The Name: " + this.greeting;
}
}
// somewhere else
arvind:Person = new Person('Arvind');

In the preceding example, we have defined a class named Person and we are defining the class constructor, which accepts the name on initialization of the class.

To initialize the class, we will invoke the class with a new keyword and pass in the name to the constructor. The variable that stores the instance of the class -- the object, arvind in the preceding example, can also be typed to the class. This helps in better understanding the possibilities of the arvind object.

Note: The classes in ES6 still follow Prototypal-based Inheritance and not the classical Inheritance model.

主站蜘蛛池模板: 延吉市| 娄烦县| 新丰县| 长治市| 东光县| 班戈县| 乌恰县| 白玉县| 许昌县| 庄河市| 酒泉市| 柘荣县| 中西区| 谢通门县| 宜章县| 高清| 拉孜县| 敖汉旗| 金川县| 常熟市| 资中县| 庄河市| 池州市| 高青县| 古交市| 长汀县| 凤翔县| 黄冈市| 凉城县| 界首市| 临沭县| 山东| 咸阳市| 万盛区| 阿拉善右旗| 蒲城县| 丹东市| 突泉县| 辽中县| 澄江县| 龙南县|