你能初始化一个函数吗? - Javascript

Can you initialize a function? - Javascript

我这里有这个函数,我需要在另一个文件中使用另一个名为 OrderRepository 的函数。

main.js

function main() {

var orderRepo = new OrderRepository();

// Your code here

}

orderrepository.js

function OrderRepository() {

}

OrderRepository.prototype.getYesterdaysOrders = function 
  getYesterdaysOrders() {
  var yesterdaysOrders = [{ array of objects }],

 return yesterdaysOrders;
};

这些是作为示例使用的,1 个问题分为 2 个部分:

1) var orderRepo = new OrderRepository();

你能像这样初始化一个函数吗?

2) 在orderrepository.js中:

function OrderRepository() {

}

main.js 中被调用,但里面没有任何内容,这是在作业中按原样给出的,这只是一个错字,他们真的是这个意思将所有内容都放入该函数中还是我遗漏了什么?

不应该是这样的吗?

预计

function OrderRepository() {

OrderRepository.prototype.getYesterdaysOrders = function 

  getYesterdaysOrders() {

  var yesterdaysOrders = [{ array of objects }],

  return yesterdaysOrders;

 };
}

关于第一部分,看起来这个作业正在处理如何在 JavaScript 中创建对象的实例,因为这就是 new 运算符所做的。

您可以找到有关 new on the MDN 的更多信息。

关于第二个问题,是处理如何创建继承方法的对象。所以,是的,它是空的,直到你到达 prototype 表达式。

expected代码在这种情况下不会给你继承。请注意 OrderRepository 是如何在函数内部重复的,这将是无效的。 Javascript 需要你为特殊的 prototype 添加继承 属性。添加到 function 声明的代码仅在这种情况下才会限定在 function 中。

您可以找到有关 prototype on the MDN 的更多信息。

深入JavaScript,语言很难理解。 JavaScript 不是真正的 OOP(恕我直言),至少它没有实现常见的 OOP 概念。有人称它为基于对象的语言。没有类。最近的 ECMA 脚本标准确实实现了 class 关键字,但是,它是语法糖。与 new 关键字一起使用,它构建的对象与您可以通过 'constructor' 函数实现的对象相同。

JavaScript中的一切都是对象,甚至是数字和函数。每个函数都可以充当构造函数。 new 关键字调用构造函数,将新创建的空对象作为函数的 this 上下文。该功能可以做它想做的事。如果它没有 return 任何东西,它的 this 上下文是由 new 表达式 return 编辑的。

既然没有类,也就没有继承。一些类似继承的行为是通过原型概念实现的。在大多数情况下,构造函数 return 什么都不做,有时会通过添加属性来修改 this 对象。方法是持有函数对象的属性。构造函数调用的 new 上下文中的对象将具有原型对象引用作为 __proto__ 属性。这是由 new 运算符从被调用构造函数的 prototype 属性 复制的。默认为空对象。

// empty constructor function
function OrderRepository() {

}

// define a function property on the constructor's prototype object
OrderRepository.prototype.getYesterdaysOrders = function 
  getYesterdaysOrders() {
  var yesterdaysOrders = [ /* array of objects */ ],

 return yesterdaysOrders;
};

// create an empty object with a `__proto__` property holding a
// reference to the object { getYesterdaysOrders: function(){/*code*/} }
var obj = new OrderRepository();

现在,当尝试调用obj.getYesterdaysOrders()方法时,JavaScript会查看obj中是否定义了这样的属性。如果没有,它会查找 obj.__proto__ 中是否有引用,并且 属性 名称会在 obj.__proto__ 的属性中搜索。如果没有,则重复相同的步骤,直到找到或者链中的__proto__属性为null。由于定义了 obj.__proto__.getYesterdaysOrders,因此检查它是否是可调用函数对象,并最终使用 objthis 上下文调用,因为我们调用了 obj.getYesterdaysOrders()。否则会抛出错误。

注意:即使主要浏览器确实公开了 __proto__ 属性,它也不是标准的一部分。不要直接使用它(开发时调试除外),更重要的是:不要操纵它。如果您确实需要在构造后获取或操作对象实例的原型(__proto__),请使用内置Object对象的方法。

根据您的最后一次编辑:您预期的代码将在每个实例化(以及构造函数调用)中的 prototype 中定义一个新的函数对象。这不是你想要的,这只是不必要的开销。