【问题标题】:Angular2: Can't find package after npm installAngular2:npm安装后找不到包
【发布时间】:2019-02-11 10:41:31
【问题描述】:

我尝试通过 npm install 安装几个包。例如:

npm install ng2-storage

该包已正确安装在 node_modules 目录中。

我尝试通过以下方式导入库:

import { StorageSettings } from 'ng2-storage';

但是当我启动 npm start 我得到这个错误:

app/main.ts(3,33): error TS2307: Cannot find module 'ng2-storage'.

每个第三方包都有这个问题。

更新:将其添加到我的系统配置中:

/**
 * 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':                        'dist', // 'dist',
    '@angular':                   'node_modules/@angular',
    'angular2-in-memory-web-api': 'node_modules/angular2-in-memory-web-api',
    'rxjs':                       'node_modules/rxjs',
    'ng2-storage':                'node_modules/ng2-storage'
  };
  // 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' },
    'ng2-storage':                { main: 'index.js', defaultExtension: 'js' },
  };
  var ngPackageNames = [
    'common',
    'compiler',
    'core',
    'forms',
    '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: 'bundles/' + 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);

ma​​in.ts

import { StorageSettings } from 'ng2-storage';

同样的问题...

【问题讨论】:

  • 您是否将下载的软件包包含在您的索引页面中?
  • 不,我认为没有必要。在开发离子应用程序时,我从来不需要手动包含它。
  • 或在您的装载机中?

标签: angular npm npm-install


【解决方案1】:

您需要将第三方包添加到您的 systemjs.config.js 文件中,这就是您告诉您的应用在哪里查找文件的地方。例如,我几分钟前安装了ng2-bootstrap,我必须添加这个:

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',
'moment': 'node_modules/moment',
'ng2-bootstrap': 'node_modules/ng2-bootstrap',
};

var packages = {
'app': { main: 'main.js', defaultExtension: 'js' },
'rxjs': { defaultExtension: 'js' },
'angular2-in-memory-web-api': { main: 'index.js', defaultExtension: 'js' },
'ng2-bootstrap': { main: 'ng2-bootstrap.js', defaultExtension: 'js' },
'moment': { main: 'moment.js', defaultExtension: 'js' },
};

搜索您的 node_modules 文件夹以查看您需要为库添加的内容。

【讨论】:

  • 我已经更新了我的系统配置但没有成功..还是同样的问题..
  • @rakete 那我觉得是ng2-storage端的问题,可能他们还没有发布RC5/RC6的更新。
  • 我会尝试其他软件包并给你反馈 ;-) 还是谢谢你!
  • 不客气,希望您能找到解决此问题的方法。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2015-12-21
  • 1970-01-01
  • 2020-10-13
  • 1970-01-01
  • 2021-06-21
  • 1970-01-01
相关资源
最近更新 更多