我在“log.ts”文件中导出一个简单的函数:
export function message(s : string) {
console.log(s);
}
这是由同一目录中的文件(“MyController.ts”)导入的:
import log = module("./log");
class MyController {
a : string = "aaa";
constructor () {
log.message("hello world");
}
}
编译时,我得到以下JS:
define(["require", "exports", "./log"], function(require, exports, __log__) {
var log = __log__;
var MyController = (function () {
function MyController() {
this.a = "aaa";
log.message("hello world");
}
return MyController;
})();
})
//@ sourceMappingURL=MyController.js.map
这个define函数应该返回MyController。因为它没有,所以此代码段内的回调不会获得控制器参数的任何内容:
require(["MyController"], function (controller) {
theRoute.controller = controller;
defer.resolve();
$rootScope.$apply();
});
我可以通过手动添加调用中的返回来修复此问题,但这不是一个好的解决方法,因为JS正在由TS编译器输出。
我做错了什么,或者这是打字稿中的错误?
答案 0 :(得分:3)
你应该写:
import log = module("./log");
export class MyController { // <--- 'export'
a : string = "aaa";
constructor () {
log.message("hello world");
}
}
和
require(["MyController"], function (controller) {
theRoute.controller = new controller.MyController(); // <--
defer.resolve();
$rootScope.$apply();
});
从0.9.x开始,您将能够在.ts文件的底部编写export = MyController;
,以使该类成为顶级导出对象。