javascript中的内置函数(例如Object.keys)没有“prototype”属性.
Object.keys.prototype === undefined; // returns true Array.prototype.slice.prototype === undefined; // returns true
但是,function(){…}或new Function()将生成构造函数(Function的实例)以及原型(Object的实例).是不是太贵了?
解决方法
除了Math.random之外,JS中的内置函数是纯粹的设计.您不应该使用新语句派生一个函数,它不会为您做正确的工作.
JavaScript是一种多范式编程语言,它暴露了功能和oop的感官.所以,你有没有原型的纯函数:
Math.round // whose typeof is function Math.floor // whose typeof is also function
在上面,Math可以被视为命名空间而不是Object类型.所以它只是一个为您提供一系列功能的容器.
相反,如果你在JavaScript中引用原型对象的函数,除非你通过原型引用它们,否则你将得到一个未定义的:
Array.map // undefined Array.reduce // undefined
这是因为Array不是像Math这样的名称空间,它是OOP意义上的一类对象.所以你需要通过它的实例调用函数,如:
var list = new Array(3); list.map(function(a){ return 1 });
否则,您可以通过原型引用该函数来访问未绑定此对象的纯函数.见以下声明:
var list = [1,2,3]; typeof(Array.prototype.map); // It's pure,unbound Array.prototype.map.call( list,function(a){ return a*2 }); // Usage in a purely-functional way
这背后的意义是,JavaScript被设计为可以在OOP和Functional方式下写入.您可能需要使用函数原型,因为我已经给出了上面的一些示例,这将进一步澄清你:)