当我尝试在angular cli中创建一个组件时,它显示了这个错误。我怎样才能摆脱它呢?

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

我使用的是angular cli版本:1.4.1


当前回答

你必须像这样指定模块名

ng g c your-component --module module-name

module-name应该是你想用新创建的组件更新的模块名。

其他回答

这是由于生成试图将您的组件添加到模块,即添加这一行

import { MyComponent } from './Components/my-component/my-component.component';

但它找到了两个模块。

正如这里所述,他们修复了一种情况,只要在根src/app文件夹中只有一个模块,就可以了,所以只需将辅助模块移动到子文件夹中。

否则你必须使用——module

Angular CLI: 8.3.4 节点:10.16.3 Angualr: 4.2.5

我使用“dotnet new angular”命令来生成项目,它已经在app文件夹中生成了3个不同的模块(尽管一个简单的ng new project-name测试只生成了一个模块。

查看项目中的模块并决定需要哪个模块-然后指定名称

ng g c componentName --module=[name-of-your-module]

你可以在这里阅读更多关于模块的信息: https://angular.io/guide/architecture-modules

我有这个警告时,有这个角。json配置:

"prefix": "app_ng"

当更改为“app”时,一切都工作得很好。

你必须像这样指定模块名

ng g c your-component --module module-name

module-name应该是你想用新创建的组件更新的模块名。

当app或lib有多个嵌套模块时

myApp
  > src
    > app
      app.module.ts
      > routes
        > login
          > auth
          login.module.ts

角CLI

ng g component routes/login/auth/my-auth --module=routes/login/login.module.ts 

NRWL NX Angular CLI

ng g component routes/login/auth/my-auth --project=myApp --module=routes/login/login.module.ts

结果

myApp
  > src
    > app
      app.module.ts
      > routes
        > login
          > auth
            > my-auth
              my-auth.component.ts etc...
          login.module.ts