在回调中重用变量/对象

Re-use variables/objects in callbacks

本文关键字:变量 对象 回调      更新时间:2023-09-26

我想知道,在下面的示例中,处理重用我的helpers对象的最佳方法是什么?

var test = {
  Projects: 'an object goes here',
  helpers: require('../helpers'),
  test: function(req, res) {
    if (this.helpers.is_post(req)) {
      // tried this
      var test = this.helpers;
      this.Projects.byCode(req.params.project_code, function(project) {
        if (!project) {
          this.helpers.flash(req, 'error', 'Unable to find project.');
          // tried this
          helpers.flash(req, 'error', 'Unable to find project.');
          res.redirect('/projects');
        }
      });
    }
  }
};

我知道我不能在回调中重用变量、对象等,因为它们不会在同一运行时执行,但仍然必须有某种更好/更清晰的方法来做这样的事情?

即使我尝试将this.helpers重新分配给另一个变量,它也给了我错误,说它是未定义的。

谢谢!

为什么你认为你不能在回调中重用变量?它们不仅在同一运行时中执行,而且在同一线程中执行!这就是 JavaScript 的美妙之处。

相反,您的问题可能是对此的误用。例如,如果没有分配给var test = this.helpers,它肯定不起作用。如果您像这样调用该方法,即使这样也不起作用:

var testIt = test.test;
testIt(req, res);

请尝试类似以下内容的操作:

var helpers = require('../helpers');
var test = {
  Projects: 'an object goes here',
  test: function(req, res) {
    if (helpers.is_post(req)) {
      this.Projects.byCode(req.params.project_code, function(project) {
        if (!project) {
          helpers.flash(req, 'error', 'Unable to find project.');
          res.redirect('/projects');
        }
      });
    }
  }
};

无论如何,将整个模块作为对象的属性确实非常荒谬。