错误 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);