js--3.对象-9.构造函数

1      构造函数

1.1  概念

构造函数是用于生成对象的函数,像之前调用的Object()就是一个构造函数。

任何函数都可以通过new来调用,所以函数都可以是构造函数。在开发中,通常会区分用于执行的函数和构造函数。

 

1.2  创建

构造函数就是一个普通的函数,创建方式和普通函数没有区别,不同的是构造函数习惯上首字母大写

js--3.对象-9.构造函数

         构造函数本身和普通的函数声明形式相同。

 

 

1.3  调用new关键字

构造函数通过new 关键字来调用,new 关键字会新创建一个对象并返回。通过new关键字调用的构造函数内的this 引用了(被新生成的)对象。

构造函数与普通函数调用区别

js--3.对象-9.构造函数

 

 

1.4  执行流程

 

1.立刻创建一个新的对象

2. 会执行相应的构造函数。将新建的对象设置为函数中this,在构造函数中可以使用this来引用新建的对象

3.逐行执行函数中的代码

4.将新建的对象作为返回值返回

 js--3.对象-9.构造函数

使用同一个构造函数创建的对象,我们称为一类对象,也将一个构造函数称为一个类。我们将通过一个构造函数创建的对象,称为是该类的实例

 

2      注意

2.1  instanceof

2.1.1  语法

语法:对象 instanceof 构造函数

    如果是,则返回true,否则返回false

js--3.对象-9.构造函数

 

2.1.2  所有对象都属于object

所有的对象都是Object的后代,所以任何对象和Object左instanceof检查时都会返回true

 

2.2  成员函数的弊端

2.2.1  成员函数都是唯一的

js--3.对象-9.构造函数

在Person构造函数中,为每一个对象都添加了一个sayName方法,目前我们的方法是在构造函数内部创建的,也就是构造函数每执行一次就会创建一个新的sayName方法,也是所有实例的sayName都是唯一的。

js--3.对象-9.构造函数

    这样就导致了构造函数执行一次就会创建一个新的方法,执行10000次就会创建10000个新的方法,而10000个方法都是一摸一样的,这是完全没有必要,完全可以使所有的对象共享同一个方法

 

2.2.2  将函数定义到全局作用域

js--3.对象-9.构造函数

只会在调用的时候执行一次,解决了每执行一次构造函数就要执行一次的弊端

js--3.对象-9.构造函数

         但是将函数定义在全局作用域,污染了全局作用域的命名空间,而且定义在全局作用域中也很不安全

 

2.2.3  引入原型

js--3.对象-9.构造函数