this对象的类型来实现。this对象是Function的实例,则表示函数是普通调用;this对象的构造函数是当前函数,则表示函数是通过new调用。JavaScript中判断函数是通过new调用还是普通调用的方法主要有两种:通过检查函数内部的this值和使用ES6引入的new.target属性,以下是详细的说明和示例:
使用 this 值判断
原理:当函数通过new关键字调用时,函数内部的this会指向一个新创建的对象,如果函数以普通方式调用(即直接调用),this通常指向全局对象或在严格模式下为undefined。

示例代码:
function MyFunction() { if (this instanceof MyFunction) { console.log('通过 new 调用'); } else { console.log('通过普通调用'); } } // 测试函数调用 new MyFunction(); // 输出:通过 new 调用 MyFunction(); // 输出:通过普通调用使用 new.target 属性判断
原理:new.target是ES6中引入的新特性,它提供了一个更直接的方式来检测函数是否通过new调用,当函数作为构造器被调用时,new.target会指向该构造函数本身,否则它的值为undefined。
示例代码:
function MyFunction() { if (new.target) { console.log('通过 new 调用'); } else { console.log('通过普通调用'); } } // 测试函数调用 new MyFunction(); // 输出:通过 new 调用 MyFunction(); // 输出:通过普通调用注意事项:new.target不受执行环境的影响,因此比this更为可靠,它不能用于区分是否通过.apply()、.call()或.bind()方法调用。
相关问题与解答
1、如何判断JavaScript中的函数是通过new调用还是普通调用?
答:可以通过检查函数内部的this值或使用new.target属性来判断,如果函数通过new调用,this将指向新创建的对象,而new.target将指向构造函数本身;如果是普通调用,this可能指向全局对象或undefined(严格模式),而new.target将为undefined。
2、有什么区别在于使用new关键字调用函数和普通调用函数的区别?
答:使用new关键字调用函数时,会创建一个新的对象并将其用作函数的this上下文,而普通调用函数则不会创建新的对象,this的值取决于调用函数时的上下文。new调用还会尝试返回构造函数中显式返回的对象,如果没有则返回新创建的对象本身。
JavaScript提供了多种方法来检测函数的调用方式,根据具体需求选择合适的方法可以提高代码的健壮性和灵活性。
以上内容就是解答有关“JavaScript中判断函数是new还是()调用的区别说明-javascript技巧”的详细内容了,我相信这篇文章可以为您解决一些疑惑,有任何问题欢迎留言反馈,谢谢阅读。