JS函数直接调用和new的区别

探讨JS中函数直接调用与使用new关键字的区别。直接调用时,this指向全局对象,可访问外部变量;使用new时,创建新对象,this指向新对象,外部变量不可见。注意返回值类型对两者的影响。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

JS中函数既可以直接调用,也可以使用new关键字来构造。那么他们的区别是什么呢?

来看一段代码:

var a = 1;
function main()
{
    console.log(a);
    var a = 2;
    console.log(this.a);
    this.a = 3;
}

main();
new main();

输出结果:

undefined
1
undefined
undefined

函数调用时,如果我们打印this,会发现this对象变成了window,而window.a = 1 ,即函数外部声明的值。

而使用new时,js把main方法当成了构造函数,属性和方法挂在了main对象上面,故会出现两个undefined。

注意:
如果函数的返回值是引用类型的,数组、对象或函数,直接调用和new一样,如果是非引用类型的,那么是不同的。

来自原文章评论截图:
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值