Maq*_*quh 6 node.js typescript systemjs
我尝试使用typescript设置一个restify项目.经过各种尝试后,我可以使用tsconfig.json中的"module:commonjs"创建一个工作版本
我更喜欢使用系统 - 但我无法使用systemjs进行设置
boot.ts
import {AppServer} from './app';
var _appServer = new AppServer();
Run Code Online (Sandbox Code Playgroud)
tsconfig.json
{
"compilerOptions": {
"target": "ES5",
"module": "commonjs",
"moduleResolution": "node",
"sourceMap": true,
"emitDecoratorMetadata": true,
"experimentalDecorators": true,
"removeComments": false,
"noImplicitAny": false
},
"exclude": [
"node_modules"
]
}
Run Code Online (Sandbox Code Playgroud)
app.ts
/// <reference path="typings/restify/restify.d.ts" />
import {Server, Response, Request, createServer} from 'restify';
export class AppServer {
private server: Server;
constructor() {
this.init();
}
init() {
this.server = createServer();
this.server.get('/hello/:name', this.respond);
this.server.listen(8080, () => {
console.log('%s listening at %s', this.server.name, this.server.url);
});
}
respond(req: Request, res: Response, next: Function) {
res.send('hello ' + req.params.name);
next();
}
}
Run Code Online (Sandbox Code Playgroud)
"module": "system"
在tsconfig.json中使用
,我得到以下输出(即使import System = require('systemjs')在boot.ts中):
? server git:(master) ? npm run server
> server@1.0.0 server /Users/maquh/Development/02_Backgular/server
> node boot.js
/Users/maquh/Development/02_Backgular/server/boot.js:1
(function (exports, require, module, __filename, __dirname) { System.register(['./app'], function(exports_1) {
^
ReferenceError: System is not defined
at Object.<anonymous> (/Users/maquh/Development/02_Backgular/server/boot.js:1:63)
at Module._compile (module.js:425:26)
at Object.Module._extensions..js (module.js:432:10)
at Module.load (module.js:356:32)
at Function.Module._load (module.js:313:12)
at Function.Module.runMain (module.js:457:10)
at startup (node.js:138:18)
at node.js:974:3
Run Code Online (Sandbox Code Playgroud)
透明的boot.js
System.register(['./app'], function(exports_1) {
var app_1;
var _appServer;
return {
setters:[
function (app_1_1) {
app_1 = app_1_1;
}],
execute: function() {
//System.import('./app.ts').
_appServer = new app_1.AppServer();
}
}
});
//# sourceMappingURL=boot.js.map
Run Code Online (Sandbox Code Playgroud)
更新:我还尝试了另一种替代版本的boot.ts
var System = require('systemjs');
System.transpiler = 'ts';
System.import('./app.js').then(function(m) {
console.log(m);
}, function(err) {
console.error(err);
});
Run Code Online (Sandbox Code Playgroud)
这些导致以下错误:
[Error: ENOENT: no such file or directory, open '/Users/markusbellgardt/Development/02_Backgular/server/restify']
Run Code Online (Sandbox Code Playgroud)
系统使用 ES6 模块加载器,nodejs(据我所知)当前不支持,您最初的用例正是您输出到commonjs. 如果你想在 Node 中使用 ES6 风格的模块解析,你需要告诉 Node 如何加载它,例如:
https://www.npmjs.com/package/es6-module-loader
我在节点中使用 typescript 很好,但我使用commonjs,我之前在浏览器中使用过system,当你有可用的 ES6 模块加载器(例如 SystemJs (JSPM))时,它工作得很好。
| 归档时间: |
|
| 查看次数: |
2598 次 |
| 最近记录: |