一.构造函数和普通函数的三个不同点
1、构造函数也是一个普通函数,创建方式与普通函数一样(构造函数习惯上首字母大写)。
2、构造函数和普通函数的主要区别在于:调用方式不一样。作用也不一样(构造函数用来新建实例对象)
3、调用方式不一样。
a. 普通函数的调用方式:
直接调用 child();
b.构造函数的调用方式:
需要使用new关键字来调用 new Child();
二.构造函数的函数名与类名相同:Child() 这个构造函数,Child 既是函数名,也是这个对象的类名。(这一点和java的构造方法类似)
三.内部用this 来构造属性和方法
//一个Child的构造函数。
function Child(name,height,age)
{
this.name=name;
this.height=height;
this.age=age;
this.sayFuck=function()
{
alert("Fuck")
}
}
四.构造函数的执行流程
1.立刻在堆内存中创建一个新的对象 //对象在外部可以实时引用,类似于全局变量
2.将新建的对象设置为函数中的this //this对象为构造函数本身,this后可以添加成员变量
3.逐个/逐行执行函数中的代码
4.将新建的对象作为返回值 //return this self
五.普通函数例子:
因为没有返回值,所以为undefined
For example:
function child(){
}
var say = child();
console.log(say);
控制台:
say is "undefined";
六.构造函数:构造函数会马上创建一个新对象,并将该新对象作为返回值返回。(下面的案例没有成员属性,对象的属性都没有的情况)
For example:
function Child(){
}
var say = new Child();
console.log(say);
控制台:
say is [object object];
七.使用instanceof 可以检查一个对象是否是一个类的实例,如是则返回true;
所有对象都是Object对象的后代,
所以任何对象和Object做instanceof都会返回true