时间:2021-05-28
本文实例讲述了ES6中class类用法。分享给大家供大家参考,具体如下:
类语法是ES6中新增的一个亮点特色。我们熟悉的JavaScript终于迎来了真正意义上的类。在之前,想要通过javascript来实现类,通常会采用如下构造函数的模式:
function Person(name,age,job){ this.name = name; this.age = age; this.job = job; this.friends = ['Shelby','Court'];}Person.prototype = { constructor:Person, sayName: function(){ document.write(this.name); }}然后通过实例化调用:
var person1 = new Person('lf',23,'software engineer');person1.sayName();下面看看使用ES6的类如何处理:
class Person { constructor(name, age, job) { this.name = name; this.age = age; this.job = job; this.friends = [‘Shelby','Court'] } sayName () { document.write(this.name); }}可以看到简便了不少。
Class语法的推出可不光光是为了简化噢,还有很多关键字。比如:
static关键字用来定义类的静态方法,静态方法是指那些不需要对类进行实例化,使用类名就可以直接访问的方法。静态方法经常用来作为工具函数:
class Point { constructor(x, y) { this.x = x; this.y = y; } static distance(a, b) { const dx = a.x - b.x; const dy = a.y - b.y; return Math.sqrt(dx*dx + dy*dy); }}const p1 = new Point(5, 5);const p2 = new Point(10, 10);console.log(Point.distance(p1, p2));但是需要注意的是,ES6中不能直接定义静态成员变量,但是我们可以通过另外的方式来实现:
static get baseUrl() { return ''}在类语法推出之前,我们想要实现继承,必须通过prototype来指定对象,而现在我们可以通过extends关键字来实现继承:
class Animal { constructor(name) { this.name = name; } speak() { console.log(this.name + ' makes a noise.'); }}class Dog extends Animal { speak() { console.log(this.name + ' barks.'); }}但是需要注意的一点就是,继承的原理还是在利用prototype这点没有变,只不过extends裹了一层语法糖而已。
希望本文所述对大家ECMAScript程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了es6中class类静态方法,静态属性,实例属性,实例方法。分享给大家供大家参考,具体如下:es6新增了一种定义对象实例的方法,使用class关键
本文实例讲述了ES6中Class类的静态方法。分享给大家供大家参考,具体如下:以前看过的es6的东西,又忘了,再总结下:类相当于实例的原型,所有在类中定义的方法
本文实例讲述了ES6class类链式继承,实例化及reactsuper(props)原理。分享给大家供大家参考,具体如下:class定义类是es6提供的新的ap
使用ES6语法重构React组件在AirbnbReact/JSXStyleGuide中,推荐使用ES6语法来编写react组件。下面总结一下使用ES6class
本文实例讲述了ES6javascript中class类的get与set用法。分享给大家供大家参考,具体如下:与ES5一样,在Class内部可以使用get和set