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

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

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

  • 10
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值