带有 'new' 关键字的函数表达式:揭开静态本质
在 JavaScript 中,了解带有 'new' 的函数表达式的行为关键词至关重要。考虑以下代码:
var gameData = new function () { // Function expressions require no constructor this.storageAvailable = function () { ... }; };
需要注意的是,这种情况下的“new”关键字并不意味着实例化或允许创建多个实例。相反,它只是执行函数表达式并将生成的匿名对象分配给“gameData”变量。
静态行为的误解
静态行为的概念C# 可能会导致误解,认为 JavaScript 中的函数表达式也是静态的。然而,这是不准确的。这里的 'new' 关键字不会阻止创建第二个对象:
var gameData2 = new (gameData.constructor)(); // Reinstantiation is possible
此外,函数表达式仍然有一个指向匿名函数的构造函数属性,可以使用 'gameData.constructor 访问它'。这违背了真正静态类的目的。
静态行为的替代品
如果意图是创建单个不可实例化的对象,那么有更合适的使用带有“new”的函数表达式的替代方案:
总之,JavaScript 中带有“new”关键字的函数表达式不表现出静态行为,因为它们可以多次实例化,并且具有可通过“gameData.constructor”访问的公共构造函数属性。对于真正的静态行为,请考虑采用替代方法,例如对象文字、显示模块模式或单例模式。
以上是JavaScript 函数表达式的'new”会创建静态行为吗?的详细内容。更多信息请关注PHP中文网其他相关文章!