【发布时间】:2014-09-05 20:54:30
【问题描述】:
我在 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()
因为这开始变得令人困惑。
【问题讨论】:
标签: javascript node.js typescript