5

如果我有这个 ts 模块:

export function say(){
    console.log("said");
}

我用 amd 选项编译它,我可以很容易地从 ts 客户端使用它:

import foo = module("tsmodule")
foo.say();

export var x = 123;

但是,如果我有与 ts 模块等效的 javascript:

define(["require", "exports"], function(require, exports) {
    function say() {
        console.log("said");
    }
    exports.say = say;
})

没有办法轻松使用它。最简单的可能解决方案:

// of course you can use .d.ts for requirejs but that is beside the point
declare var require:any;

// will fail with error module has not been loaded yet for context
// http://requirejs.org/docs/errors.html#notloaded
var useme = require("jsmodule")
useme.say();

export var x = 123;
import foo = module("tsmodule")
foo.say();

由于错误http://requirejs.org/docs/errors.html#notloaded失败。由于“jsmodule”未传递给生成的打字稿中的定义调​​用。

我有两种解决方法

  • 不要使用导入/导出(语言功能丢失)
  • 使用 require([]) (仍然不能导出依赖于 require([]) 调用的东西)

有限制:https ://github.com/basarat/typescript-requirejs 。还有其他方法吗?如果不能,你可以在这里投票:https ://typescript.codeplex.com/workitem/948 :)

4

1 回答 1

3

如果你想加载一个 JavaScript 模块,你总是可以使用(错误记录的)amd-dependency标签:

/// <amd-dependency path="jsmodule" />

这将放入jsmodule您定义调用的依赖数组中。

然后提供一个声明文件,您只需在其中声明

module useme {
    function say(): void;
}
于 2013-04-25T12:03:33.743 回答