构造函数与普通函数的区别

一.构造函数和普通函数的三个不同点

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

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容