Javascript:没有原型的函数

前端之家收集整理的这篇文章主要介绍了Javascript:没有原型的函数前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
javascript中的内置函数(例如Object.keys)没有“prototype”属性.
Object.keys.prototype === undefined;             // returns true
Array.prototype.slice.prototype === undefined;   // returns true

但是,function(){…}或new Function()将生成构造函数(Function的实例)以及原型(Object的实例).是不是太贵了?

有可能在javascript中创建纯函数而不是构造函数吗?

解决方法

除了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方式下写入.您可能需要使用函数原型,因为我已经给出了上面的一些示例,这将进一步澄清你:)

猜你在找的JavaScript相关文章