- 在生成具有多个模块

时间:2018-04-17 14:43:37

标签: angular angular-cli

所以我面对这个奇怪的问题。我的角度应用程序中有5个带路由模块的模块。我正在尝试使用该命令在第五个模块中创建一个组件。在我正在尝试创建组件的文件夹中,我删除了路由模块,以便最近的模块是应该导入的模块。它工作正常,因为它找到最近的模块,但是当存在--skip-import标志时它不应该这样做但是它会这样做。

ng g c path/to/component/name --skip-import 

但我得到了错误

  

错误:多个模块匹配。使用skip-import选项跳过将组件导入最近的模块。   多个模块匹配。使用skip-import选项跳过将组件导入最近的模块。

我尝试使用--module标志来指定模块但仍然遇到相同的错误。之前已经成功使用过。

在第二种情况下,我有2个模块并尝试创建一个成功创建的组件,但即使存在--skip-import标志,也会导入到最近的模块。

Angular CLI Docs for generating component

以下是截图。

--skip-import present still imports

Error When --module flag is specified

这是我做错了还是错误?如果但是没有运气的话,几乎要花几个小时的努力才能解决这个问题。

已经提到了这些问题。但没有运气

Question1 Question2

我的@angular版本细节

"dependencies": {
    "@angular/animations": "^5.2.10",
    "@angular/common": "^5.2.10",
    "@angular/compiler": "^5.2.10",
    "@angular/core": "^5.2.10",
    "@angular/forms": "^5.2.10",
    "@angular/http": "^5.2.10",
    "@angular/platform-browser": "^5.2.10",
    "@angular/platform-browser-dynamic": "^5.2.10",
    "@angular/router": "^5.2.10",
    "bootstrap": "^4.1.0",
    "core-js": "^2.5.5",
    "file-saver": "^1.3.8",
    "font-awesome": "^4.7.0",
    "g": "^2.0.1",
    "jquery": "^3.3.1",
    "moment": "^2.22.1",
    "ng-pick-datetime": "^5.2.4",
    "ng-pick-datetime-moment": "^1.0.5",
    "ngx-pagination-bootstrap": "^1.5.0",
    "ngx-select-dropdown": "^0.2.1",
    "ngx-slides": "^1.0.1",
    "rxjs": "^5.5.10",
    "tether": "^1.4.4",
    "zone.js": "^0.8.26"
  },
  "devDependencies": {
    "@angular/cli": "^1.7.4",
    "@angular/compiler-cli": "^5.2.10",
    "@angular/language-service": "^5.2.10",
    "@types/jasmine": "~2.8.3",
    "@types/jasminewd2": "~2.0.2",
    "@types/node": "^6.0.106",
    "codelyzer": "^4.0.1",
    "gh-pages": "^1.1.0",
    "jasmine-core": "~2.8.0",
    "jasmine-spec-reporter": "~4.2.1",
    "karma": "~2.0.0",
    "karma-chrome-launcher": "~2.2.0",
    "karma-coverage-istanbul-reporter": "^1.2.1",
    "karma-jasmine": "~1.1.0",
    "karma-jasmine-html-reporter": "^0.2.2",
    "protractor": "~5.1.2",
    "ts-node": "~4.1.0",
    "tslint": "~5.9.1",
    "typescript": "~2.7.2"
  }

2 个答案:

答案 0 :(得分:1)

你应该用它来运行生成它。它将为您生成文件夹和组件。

ng generate component folder_name --module app

答案 1 :(得分:0)

尽管我对此反应有点晚。 但是这里有一种可行的解决方案,一种对我有用的解决方案。

  1. 确保将角度添加到环境路径中。这是一篇可以为您提供帮助的帖子(add angular to environment variables)
  2. 使angular和angular-cli上的版本全局和局部兼容
  3. 尝试清除npm缓存,然后再次运行npm install
  4. 如果以上方法均无效,则应完全卸载angular和angular-cli并尝试重新安装。

最后一个为我解决了问题,但其他人也派上了用场,因为前三个步骤中的任何一个都帮助其他同事解决了类似的问题。

希望这会有所帮助:)