psn*_*der 7 javascript module amd external typescript
如何将javascript AMD模块导入外部TypeScript模块?
我正在模块化我的客户端TypeScript程序以使用由bower管理的AMD模块.作为此过程的一部分,Typescript模块成为一个javascript AMD模块,然后我发布.现在我有一个我希望包含在TypeScript模块中的javascript AMD模块,我不想发布带有javascript AMD的原始TypeScript.
我无法弄清楚如何编写我的TypeScript代码,以便它将加载没有相应TypeScript的javascript AMD模块,并且看起来最新版本的TypeScript还不支持这个.
如果我从0.9.7 TypeScript规范的示例开始,请参见第11.2节:
文件main.ts:
import log = require("./log");
log.message("hello");
Run Code Online (Sandbox Code Playgroud)
文件log.ts:
export function message(s: string) {
console.log(s);
}
Run Code Online (Sandbox Code Playgroud)
我相信我应该能够修改main.ts,以便编译器解析对log.js AMD模块的"log"引用.下面是通过运行tsc --module amd main.ts生成的log.js文件.这是一个正确的AMD模块.
文件log.js:
define(["require", "exports"], function(require, exports) {
function message(s) {
console.log(s);
}
exports.message = message;
});
Run Code Online (Sandbox Code Playgroud)
要模拟具有javascript AMD模块,请编译上面的示例,然后删除log.ts文件.如果您现在尝试使用相同的命令进行编译,则会因以下错误而失败:
./main.ts(1,1): error TS2071: Unable to resolve external module '"./log"'.
./main.ts(1,1): error TS2072: Module cannot be aliased to a non-module type.
Run Code Online (Sandbox Code Playgroud)
我现在如何修改main.ts以便它编译并解析这个log.js AMD模块?如果必须的话,我可以编写log.d.ts文件,但是想要一个没有声明文件的方法.
如果我可以在规范的TypeScript方式中学习如何做到这一点,那么我可以继续完成我的项目的模块化.
我现在如何修改 main.ts 以便加载和使用此 log.js AMD 模块?
如果您只有 log.js 可用,您可以log
使用declare
ie 创建一个告诉 typescript 有关类型信息log.d.ts
:
declare module 'log'{
export function message(s:string);
}
Run Code Online (Sandbox Code Playgroud)
然后从 main.ts 中使用它:
/// <reference path='log.d.ts'/>
import log = require('log');
log.message("hello");
Run Code Online (Sandbox Code Playgroud)