如何使用Typescript / node.js在其他模块中直接使用其他模块?

时间:2014-07-15 15:17:43

标签: javascript node.js typescript

我在node.js下运行这个Javascript代码。我在多个模块中声明函数并使用扩展实用程序,因此可以在其他模块中使用:

// File: util.js:
var Util = function () {
    this.doTask1 = function(name) { return 9; };
}
module.exports = new Util();

// File: base.js:
var util    = require('../../Utils/util.js');
var helpers = require('../../Utils/helpers.js');
var AdminBase = function () {
    var self = this;
    this.doTask2 = function(name) { return 99; };
}
module.exports = helpers.extend({}, util, new AdminBase());

// File: page.js:
var base = require('../Common/base.js');
var Page = function () {
   base.doTask1()
   base.doTask2()

// File: helpers.js
var extend = function (target) {
   var sources = [].slice.call(arguments, 1);
   sources.forEach(function (source) {
      for (var prop in source) {
         target[prop] = source[prop];
      }
   });
   return target;
};
module.exports.extend = extend;

我现在想要使用Typescript做同样的事情,我需要一些帮助。到目前为止,我理解我需要对模块的导入进行编码,如下所示:

// File: util.ts
module Util {
   export function doTask1(name) { return 9; };
}
export = Util;

// File: base.ts
import util = require('../../Utils/util');
import helpers = require('../../Utils/helpers.js');
var AdminBase = function () {
   var self = this;
   this.doTask2 = function(name) { return 99; };
}
module.exports = helpers.extend({}, util, new AdminBase());

// File: page.js:
import base = require('../Common/base.js');
var Page = function () {
   base.doTask1()
   base.doTask2()

我对如何对此进行编码感到困惑,以便我可以访问doTask1() 和doTask2()函数的运行方式与我使用第一种方法时的方式相同。

有人可以给我建议并告诉我如何处理函数的导出,以便我可以像以前一样访问这些函数。

请注意,我不想要的是必须编码:

util.doTask1()
base.doTask2()

因为这开始变得混乱。

1 个答案:

答案 0 :(得分:2)

如果你想做

base.doTask1()
base.doTask2()

您需要从基地输出doTask1 / doTask2,即

// File: base.ts
import util = require('../../Utils/util');
import helpers = require('../../Utils/helpers.js');

export var doTask1 = util.doTask1;
export var doTask2 = function(name) { return 99; };