有人知道怎么做module.exports吗?
我尝试了一些不同的方式结束
export class Greeter {}
将编译为
exports.Greeter = Greeter;
但我真正想要的是:
exports = Greeter;
所以我可以像这样使用它:
import { Greeter } from "greeter";
const greeter = new Greeter();
而不是
import { Greeter } from "greeter";
const greeter = new Greeter.Greeter();
这可以用Typescript吗?
答案 0 :(得分:61)
您可以在TypeScript中导出单个类,如下所示:
class Person {
private firstName: string;
private lastName: string;
constructor(firstName: string, lastName: string) {
this.firstName = firstName;
this.lastName = lastName;
}
public getFullName() {
return `${this.firstName} ${this.lastName}`;
}
}
export = Person;
以下是它将如何使用:
var Person = require('./dist/commonjs/Person.js');
var homer = new Person('Homer', 'Simpson');
var name = homer.getFullName();
console.log(name); // Homer Simpson
要完成,这是我的 tsconfig.json (我正在使用TypeScript v2.0.3):
{
"compilerOptions": {
"module": "commonjs",
"moduleResolution": "node",
"outDir": "dist/commonjs",
"rootDir": "src/ts",
"target": "es5"
},
"exclude": [
"dist",
"node_modules"
]
}
答案 1 :(得分:20)
现在已经实现了,并且在TypeScript 0.9中已经准备好了:)
答案 2 :(得分:8)
所以我想我找到了一个解决方法。只需将关键字“module”包装在.ts文件的括号中即可:
declare var module: any;
(module).exports = MyClass;
生成的javascript文件将完全相同:
(module).exports = MyClass;
注意,比自己声明var模块更好,下载node.d.ts definition file并将其粘贴在与typescript文件相同的目录中。以下是express node.js路由文件的完整示例,该文件假定node.d.ts位于同一目录中:
/// <reference path="node.d.ts" />
var SheetController = function () {
this.view = function (req, res) {
res.render('view-sheet');
};
};
(module).exports = SheetController;
然后我可以新建一个SheetController并(使用express)分配视图方法:
var sheetController = new SheetController();
app.get('/sheet/view', sheetController.view);
我认为可以使用此模式转义任何关键字:
declare var reservedkeyword: any;
(reservedkeyword).anything = something;
答案 3 :(得分:2)
这很丑陋,但你仍然能做到:
class Greeter {}
declare var exports:any;
exports = Greeter;
编译成:
var Greeter = (function () {
function Greeter() { }
return Greeter;
})();
exports = Greeter;