javascript - Angular2 RC2 - 快速启动项目无法生成 2 个 .umd.js 文件

标签 javascript angular

今天在 https://angular.io/docs/ts/latest/tutorial/ 学习快速入门教程时当我到达步骤时

npm start

我看到两个 404 缺失错误:

404 GET /node_modules/@angular/platform-browser-dynamic/platform-browser-dynamic.umd.js
404 GET /node_modules/@angular/core/core.umd.js

我直接从教程中复制了 systemjs.config.js 和其他文件(见下文)。这是使用 2.0.0-rc.2。有 Angular 专家知道目前的快速入门代码有什么问题吗?我应该尝试使用 webpack 工具吗?

/**
 * System configuration for Angular 2 samples
 * Adjust as necessary for your application needs.
 */
(function(global) {
  // map tells the System loader where to look for things
  var map = {
    'app':                        'app', // 'dist',
    '@angular':                   'node_modules/@angular',
    'angular2-in-memory-web-api': 'node_modules/angular2-in-memory-web-api',
    'rxjs':                       'node_modules/rxjs'
  };
  // packages tells the System loader how to load when no filename and/or no extension
  var packages = {
    'app':                        { main: 'main.js',  defaultExtension: 'js' },
    'rxjs':                       { defaultExtension: 'js' },
    'angular2-in-memory-web-api': { main: 'index.js', defaultExtension: 'js' },
  };
  var ngPackageNames = [
    'common',
    'compiler',
    'core',
    'http',
    'platform-browser',
    'platform-browser-dynamic',
    'router',
    '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: pkgName + '.umd.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);

最佳答案

你的packUmd函数应该是这样的:

// Bundled (~40 requests):
function packUmd(pkgName) {
  packages['@angular/' + pkgName] = { 
     main: '/bundles/' + pkgName + '.umd.js', //bundles path
     defaultExtension: 'js' 
  };
}

注意/bundles/

关于javascript - Angular2 RC2 - 快速启动项目无法生成 2 个 .umd.js 文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37866936/

相关文章:

javascript - 数据表: How to show the show Entries dropdown beside the Showing 0 to 0 of 0 entries in the table structure

javascript - moment.calendar() 显示 "Tomorrow",而预期为 "Today"

javascript - 将 URL 替换为 HTML Jquery

javascript - 不允许函数在执行后一段时间内继续执行

javascript - 我收到 "Object Required"错误消息

javascript - 我想将子文件夹页面内容与主文件夹中的页面链接

Angular2 ng-bootstrap : Reuse modal template with different data

javascript - 回调中的 Node.js 发射器空数据

angular - 为什么我可以通过修改从选择器接收的对象来修改状态?

javascript - Angular 10 |邮寄 |字符串数组追加 FormData