Sto usando Typescript con SystemJS per il caricamento del modulo e Gulp per task runner nel mio progetto Angular 2. La versione corrente di Angular nel progetto è RC2 ma il problema è presente anche con RC1. Ho seguito i passaggi della risposta di Brando here.Come associare l'app Angular 2 Typescript usando Gulp e SystemJS?
Dopo bundling la mia domanda e caricamento iniziale delle SystemJS sito tiri di errore:
Error: http://localhost:57462/app/app.bundle.js detected as register but didn't execute.
I lavori di applicazione, ma l'errore nella console sicuramente non è una buona cosa.
Ho testato la mia configurazione su progetto vuoto e il problema è nuovamente presente quindi penso che il problema sia nella configurazione.
Eccolo:
Gulpfile
var gulp = require('gulp');
var sourcemaps = require('gulp-sourcemaps');
var concat = require('gulp-concat');
var typescript = require('gulp-typescript');
var jspm = require('gulp-jspm-build');
gulp.task('compile:ts', function() {
return gulp.src(['./appTS/**/*.ts'])
.pipe(sourcemaps.init())
.pipe(typescript({
noEmitOnError: true,
target: 'ES5',
removeComments: false,
experimentalDecorators: true,
emitDecoratorMetadata: true,
module: 'system',
moduleResolution: 'node'
}))
.pipe(sourcemaps.write('./'))
.pipe(gulp.dest('./app/'));
});
gulp.task('copy:vendor', function() {
return gulp.src([
'node_modules/systemjs/dist/system-polyfills.js',
'node_modules/reflect-metadata/Reflect.js',
'node_modules/core-js/client/shim.min.js',
'node_modules/zone.js/dist/zone.min.js',
'node_modules/systemjs/dist/system.js',
'node_modules/rxjs/bundles/Rx.js'
]).pipe(gulp.dest('./assets/vendor/'));
});
gulp.task('bundle:app', ['compile:ts'], function() {
return jspm({
bundleOptions: {
minify: true,
mangle: false
},
bundleSfx: true,
bundles: [
{ src: './app/main.js', dst: 'bundle.js' }
]
})
.pipe(gulp.dest('./app/'));
});
gulp.task('bundle', ['bundle:app', 'copy:vendor'], function() {
return gulp.src([
'./assets/vendor/Reflect.js',
'./assets/vendor/shim.min.js',
'./assets/vendor/zone.min.js',
'./app/bundle.js'])
.pipe(concat('app.bundle.js'))
.pipe(gulp.dest('./app/'))
});
gulp.task('default', ['bundle']);
var packages = {
app: {
format: 'register',
defaultExtension: 'js'
},
"symbol-observable": { main: 'index.js', defaultExtension: 'js' },
"reflect-metadata": { main: 'Reflect.js', defaultExtension: 'js' }
};
var ngPackageNames = ['common',
'compiler',
'core',
'http',
'platform-browser',
'platform-browser-dynamic',
'router',
'router-deprecated',
'upgrade'];
ngPackageNames.forEach(function (element, index, array) {
packages['@angular/' + element] = { main: 'bundles/' + element + '.umd.min.js', defaultExtension: 'js' };
});
System.config({
main: 'dispel.bundle.min',
defaultExtension: 'js',
format: 'register',
packages: packages,
baseURL: "/",
defaultJSExtensions: true,
transpiler: false,
paths: {
"node_modules*": "node_modules*",
"@angular*": "node_modules/@angular/*"
},
map: {
"@angular": "node_modules/@angular",
"symbol-observable": "node_modules/symbol-observable",
"ng2-translate": "node_modules/ng2-translate",
"es6-shim": "node_modules/es6-shim",
"reflect-metadata": "node_modules/reflect-metadata",
"rxjs": "node_modules/rxjs",
"zone.js": "node_modules/zone.js"
}
});
Si può creare un repo potremmo clonare e test? – Sasxa
Inoltre, un motivo particolare per cui state usando il formato 'system' /' register'? Cosa succede se usi '" module ":" commonjs "' in TS compier e 'format": "cjs" 'in System config? – Sasxa
Non c'è una ragione particolare per quello.L'errore non viene più generato da SystemJS ma si è verificato un nuovo errore: "crypto.js non trovato". Ho aggiunto '" crypto ":" node_modules/crypto-js/index.js "' mappando in System.config -> sezione map e tutto funziona ma SystemJS fa richieste separate per ognuno dei file crypto-js (circa 30). –