什么是构造函数
// 这是一个普通函数function range() {console.log(this); // 打印window}// 调用range()// 这是一个构造函数function Range() {console.log(this);// 打印Range()}// 调用var o = new Range();
es5中,生成实例对象通过构造函数来生成:
function Fun(a,b) {this.a = a;this.b = b;}Fun.prototype.showA = function () {console.log(this.a)}var fun = new Fun(1,2);fun.showA();//1
es6则引用了class的概念,使得更接近java、c++等语言,更加直观。如:
class Fun {constructor(a,b){this.a = a;this.b = b;}showA() {console.log(this.a);}}var fun = new Fun(1,2);fun.showA();//1
这两种写法是一样的,在es6中,class可以理解为一个语法糖,只是让这种写法更加直观。
要注意的是,es6中声明新的实例必须要用new声明。
其中constructor为类的默认方法,通过new的调用可以执行这个方法。每个类都必须要有这个方法,如果没有显示定义,则一个空的constructor被添加到类里面。constructor方法默认返回实例对象,即this。也可以返回其他对象。这事,新的实例instanceof当前class就会报错。
