Ho provato a configurare un progetto di restify usando typescript. Dopo vari tentativi sono stato in grado di creare una versione di lavoro utilizzando "Modulo: commonjs" nel tsconfig.jsonImpostazione di TypeScript per nodo usando module = system non funziona
preferisco usare il sistema - ma non ero in grado di configurarlo con systemjs
boot.ts
import {AppServer} from './app';
var _appServer = new AppServer();
tsconfig.json
{
"compilerOptions": {
"target": "ES5",
"module": "commonjs",
"moduleResolution": "node",
"sourceMap": true,
"emitDecoratorMetadata": true,
"experimentalDecorators": true,
"removeComments": false,
"noImplicitAny": false
},
"exclude": [
"node_modules"
]
}
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();
}
}
utilizzando "module": "system"
nel tsconfig.json, ottengo il seguente output (anche con import System = require('systemjs')
nelle boot.ts):
➜ server git:(master) ✗ npm run server
> [email protected] 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
Transpiled avvio .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
UPDATE: Ho provato anche un'altra versione alternativa di boot.ts
var System = require('systemjs');
System.transpiler = 'ts';
System.import('./app.js').then(function(m) {
console.log(m);
}, function(err) {
console.error(err);
});
quei cavi per il seguente errore:
[Error: ENOENT: no such file or directory, open '/Users/markusbellgardt/Development/02_Backgular/server/restify']
Qual è esattamente il problema? Come sai che non sei stato capace? – Pablo
Aggiunto terminale output – Maquh
si sta visualizzando 'boot.ts', che non sembra avere la linea che sembra bloccarsi da' boot.js'. puoi mostrare il contenuto del disco (output compilato) di 'boot.js'? – Claies