JS中构造函数和普通函数的区别

构造函数也是函数,来看代码:

//定义构造函数
function Person(name){
    this.name=name
    Person.prototype.age=16
}
//创建实例对象
let p=new Person('Kobe')
console.log(p.name)		//	Kobe
console.log(p.age)		//	16

//创建普通函数
function getName(){
    console.log(p.name)
}
//调用普通函数
getName()		//	Kobe

构造函数也是函数,不难看出构造函数和普通函数的定义方式是一样的。

构造函数和普通函数的显著区别在于二者的调用方式和用途不用:

  • 构造函数通过new关键字来调用,用来创建实例对象
//定义构造函数
function Person(name){
    this...
    ...
}
//创建实例对象
let p=new Person('Kobe')
  • 普通函数直接调用,是用来执行特定任务的代码块
//创建普通函数
function getName(){
    console.log(p.name)
}
//调用普通函数
getName()

通过new关键字来调用构造函数会执行如下操作:

1.在堆内存中创建一个新的对象

2.this指向这个新对象

3.执行函数中的代码(通过this语句为新对象添加属性)

4.返回这个新对象

上述执行操作第四点需要注意的是:如果在构造函数中执行return语句,并返回一个非空对象,那么构造函数执行完毕后会将这个对象返回,并不会返回在堆内存中创建的新对象。看如下示例:

//定义构造函数
function Person(name){
    this.name=name
    Person.prototype.age=16
    return{
        msg:'hello world'
    }
    
}
//创建实例对象
let p=new Person('Kobe')
console.log(p)		//	{msg: "hello world"}

这里的构造函数执行return语句返回了非空对象:{msg: “hello world”},最终构造函数会返回该对象,并不会返回在堆内存中创建的新对象。如果return语句返回的不是非空对象而是其他值,又或者没有return语句,则返回堆内存中创建的对象。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值