错误 404:找不到@angular/router/bundles/router.umd.js
Error 404: Cannot found @angular/router/bundles/router.umd.js
我正在 Angular 2 中设置路由,根据他们 website 的文档,一切都是一样的。
这是我在 app.component.ts
中导入的示例
import {Component} from '@angular/core';
import {ROUTER_DIRECTIVES} from '@angular/router';
@Component({
selector: 'my-app',
templateUrl: 'app/templates/html/app.component.html',
directives: [ROUTER_DIRECTIVES]
})
export class AppComponent{
}
不幸的是我遇到了这个错误。
我查看我的文件树,发现@angular/router
中没有 bundles 文件夹
这是一个错误吗?我怎样才能解决这个问题?谢谢!
路由器包目前没有捆绑包。
所以检查你的 systemjs 配置。我问你忘了下面这行:
// No umd for router yet
packages['@angular/router'] = { main: 'index.js', defaultExtension: 'js' };
另见 https://github.com/alexzuza/angular2-typescript-systemjs/blob/master/systemjs.config.js#L40
这是来自您的 systemjs 文件。
首先你可以映射 ng2 路由器模块,类似于你的应用程序:
var map = {
<...>
'@angular/router': 'node_modules/@angular/router',
<...>
};
接下来为其手动设置 packIndex:
packages['@angular/router'] = { main: 'index.js', defaultExtension: 'js' };
要修复此错误,请根据您的具体情况调整以下代码。
注意您要使用的不同 ng2 模块和版本以及您的应用程序名称(如果适用,请更改):
(function(global) {
// map tells the System loader where to look for things
var map = {
'YourApp': 'YourApp', // 'dist',
'@angular': 'node_modules/@angular',
'@angular/router': 'node_modules/@angular/router',
'rxjs': 'node_modules/rxjs'
};
// packages tells the System loader how to load when no filename and/or no extension
var packages = {
'YourApp': { main: 'app.js', defaultExtension: 'js' },
'rxjs': { defaultExtension: 'js' }
};
var ngPackageNames = [
'common',
'forms',
'compiler',
'core',
'http',
'platform-browser',
'platform-browser-dynamic',
'router-deprecated',
'upgrade',
];
// Individual files (~300 requests):
function packIndex(pkgName) {
packages['@angular/'+pkgName] = { main: 'index.js', defaultExtension: 'js' };
}
// Bundled (~40 requests):
function packUmd(pkgName) {
packages['@angular/'+pkgName] = { main: 'bundles/' + pkgName + '.umd.js', defaultExtension: 'js' };
}
packages['@angular/router'] = { main: 'index.js', defaultExtension: 'js' };
// Most environments should use UMD; some (Karma) need the individual index files
var setPackageConfig = System.packageWithIndex ? packIndex : packUmd;
// Add package entries for angular packages
ngPackageNames.forEach(setPackageConfig);
var config = {
map: map,
packages: packages
};
System.config(config);
})(this);
我正在 Angular 2 中设置路由,根据他们 website 的文档,一切都是一样的。
这是我在 app.component.ts
中导入的示例import {Component} from '@angular/core';
import {ROUTER_DIRECTIVES} from '@angular/router';
@Component({
selector: 'my-app',
templateUrl: 'app/templates/html/app.component.html',
directives: [ROUTER_DIRECTIVES]
})
export class AppComponent{
}
不幸的是我遇到了这个错误。
我查看我的文件树,发现@angular/router
中没有 bundles 文件夹这是一个错误吗?我怎样才能解决这个问题?谢谢!
路由器包目前没有捆绑包。
所以检查你的 systemjs 配置。我问你忘了下面这行:
// No umd for router yet
packages['@angular/router'] = { main: 'index.js', defaultExtension: 'js' };
另见 https://github.com/alexzuza/angular2-typescript-systemjs/blob/master/systemjs.config.js#L40
这是来自您的 systemjs 文件。
首先你可以映射 ng2 路由器模块,类似于你的应用程序:
var map = {
<...>
'@angular/router': 'node_modules/@angular/router',
<...>
};
接下来为其手动设置 packIndex:
packages['@angular/router'] = { main: 'index.js', defaultExtension: 'js' };
要修复此错误,请根据您的具体情况调整以下代码。
注意您要使用的不同 ng2 模块和版本以及您的应用程序名称(如果适用,请更改):
(function(global) {
// map tells the System loader where to look for things
var map = {
'YourApp': 'YourApp', // 'dist',
'@angular': 'node_modules/@angular',
'@angular/router': 'node_modules/@angular/router',
'rxjs': 'node_modules/rxjs'
};
// packages tells the System loader how to load when no filename and/or no extension
var packages = {
'YourApp': { main: 'app.js', defaultExtension: 'js' },
'rxjs': { defaultExtension: 'js' }
};
var ngPackageNames = [
'common',
'forms',
'compiler',
'core',
'http',
'platform-browser',
'platform-browser-dynamic',
'router-deprecated',
'upgrade',
];
// Individual files (~300 requests):
function packIndex(pkgName) {
packages['@angular/'+pkgName] = { main: 'index.js', defaultExtension: 'js' };
}
// Bundled (~40 requests):
function packUmd(pkgName) {
packages['@angular/'+pkgName] = { main: 'bundles/' + pkgName + '.umd.js', defaultExtension: 'js' };
}
packages['@angular/router'] = { main: 'index.js', defaultExtension: 'js' };
// Most environments should use UMD; some (Karma) need the individual index files
var setPackageConfig = System.packageWithIndex ? packIndex : packUmd;
// Add package entries for angular packages
ngPackageNames.forEach(setPackageConfig);
var config = {
map: map,
packages: packages
};
System.config(config);
})(this);