首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >从角5升级到角7后,没有为“NgModule”找到“AppModule”元数据

从角5升级到角7后,没有为“NgModule”找到“AppModule”元数据
EN

Stack Overflow用户
提问于 2019-03-24 02:19:46
回答 6查看 9.6K关注 0票数 7

我们的开发团队最近将一个角5项目更新为角7。我已经下载了回购程序,并试图构建源代码,但是当我运行ng build命令时,在“AppModule”中没有找到NgModule元数据时,会出现一个错误。

如果我运行ng -version命令,它将显示以下内容:

  • 角CLI: 7.3.6
  • 节点: 11.10.0
  • 操作系统: win32 x64
  • 角度: 7.2.10

app.module.ts文件是:

代码语言:javascript
复制
import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { AppRoutingModule } from './app-routing.module';
import { AppComponent } from './app.component';
import { AdminComponent } from './layout/admin/admin.component';
import { AdminComponent1 } from './layout/admin1/estimate.component';
import { AuthComponent } from './layout/auth/auth.component';
import { BrowserAnimationsModule } from '@angular/platform-browser/animations';
import { SharedModule } from './shared/shared.module';
import { MenuItems } from './shared/menu-items/menu-items';
import { BreadcrumbsComponent } from './layout/admin/breadcrumbs/breadcrumbs.component';
import { ServicesProvider } from '../providers/services';
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
import { AuthGuardService } from './activate-guard';
import { AuthLoginService } from './deactivate-guard';
import { SupperAdmin } from './supperadmin-guard';
import { NgProgressModule } from 'ngx-progressbar';
import {SimpleNotificationsModule} from 'angular2-notifications';
import { ConfigService } from '../assets/config/ConfigService';


@NgModule({
  declarations: [
    AppComponent,
    AdminComponent,
    AdminComponent1,
    AuthComponent,
    BreadcrumbsComponent,
  ],
  imports: [
    BrowserModule,
    BrowserAnimationsModule,
    FormsModule,
    ReactiveFormsModule,
    AppRoutingModule,
    SharedModule,
    NgProgressModule,
    SimpleNotificationsModule.forRoot(),
    BrowserModule,


  ],
  providers: [MenuItems, ServicesProvider, AuthGuardService, SupperAdmin, AuthLoginService,  NgProgressModule, ConfigService],
  bootstrap: [AppComponent]
})
export class AppModule { }

main.ts文件是:

代码语言:javascript
复制
import { enableProdMode } from '@angular/core';
import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { AppModule } from './app/app.module';
import { environment } from './environments/environment';

if (environment.production) {
  enableProdMode();
}
platformBrowserDynamic().bootstrapModule(AppModule)
  .catch(err => console.log(err));

index.html如下:

代码语言:javascript
复制
<!doctype html>
<html lang="en">

<head>
  <meta charset="utf-8">
  <title>Welcome</title>
  <base href="/">
  <!-- <script src="//ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script> -->
<script async defer src="https://maps.googleapis.com/maps/api/js?key=xxx"></script>
<!-- <script src="https://maps.googleapis.com/maps/api/js"
async defer></script> -->
  <!-- <script src="../src/assets/js/pdf.js"></script>
  <script src="../src/assets/js/pdf.worker.js"></script> -->
  <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.2.4/jquery.min.js"></script>
  <script src="//netdna.bootstrapcdn.com/bootstrap/3.1.1/js/bootstrap.min.js"></script>

  <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=0, minimal-ui">
  <meta http-equiv="X-UA-Compatible" content="IE=edge" />
  <meta name="description" content="Visual Estimator" />
  <meta name="keywords" content="visualestimator" />
  <meta name="author" content="phoenixcoded" />
  <meta http-equiv="Cache-Control" content="no-cache, no-store, must-revalidate"/>
  <meta http-equiv="Pragma" content="no-cache"/>
  <meta http-equiv="Expires" content="0"/>
  <link rel="icon" type="image/x-icon" href="favicon.ico">
  <style>
  </style>
  <!-- Google font-->
  <link href="https://fonts.googleapis.com/css?family=Roboto:400,500" rel="stylesheet">
  <link href="https://cdn.jsdelivr.net/npm/ng2-toastr@4.1.2/ng2-toastr.css" rel="stylesheet" />
</head>

<body>
  <app-root>
    <div class="theme-loader">
      <div class="loader-track">
        <div class="preloader-wrapper">
          <div class="spinner-layer spinner-blue">
            <div class="circle-clipper left">
              <div class="circle"></div>
            </div>
            <div class="gap-patch">
              <div class="circle"></div>
            </div>
            <div class="circle-clipper right">
              <div class="circle"></div>
            </div>
          </div>
          <div class="spinner-layer spinner-red">
            <div class="circle-clipper left">
              <div class="circle"></div>
            </div>
            <div class="gap-patch">
              <div class="circle"></div>
            </div>
            <div class="circle-clipper right">
              <div class="circle"></div>
            </div>
          </div>

          <div class="spinner-layer spinner-yellow">
            <div class="circle-clipper left">
              <div class="circle"></div>
            </div>
            <div class="gap-patch">
              <div class="circle"></div>
            </div>
            <div class="circle-clipper right">
              <div class="circle"></div>
            </div>
          </div>

          <div class="spinner-layer spinner-green">
            <div class="circle-clipper left">
              <div class="circle"></div>
            </div>
            <div class="gap-patch">
              <div class="circle"></div>
            </div>
            <div class="circle-clipper right">
              <div class="circle"></div>
            </div>
          </div>
        </div>
      </div>
    </div>
  </app-root>
</body>
<script src='https://api.tiles.mapbox.com/mapbox.js/plugins/leaflet-image/v0.0.4/leaflet-image.js'></script>
<script>
</script>
</html>

和angular.json文件:

代码语言:javascript
复制
{
  "$schema": "./node_modules/@angular/cli/lib/config/schema.json",
  "version": 1,
  "newProjectRoot": "projects",
  "projects": {
    "mega-able": {
      "root": "",
      "sourceRoot": "src",
      "projectType": "application",
      "architect": {
        "build": {
          "builder": "@angular-devkit/build-angular:browser",
          "options": {
            "outputPath": "dist",
            "index": "src/index.html",
            "main": "src/main.ts",
            "tsConfig": "src/tsconfig.app.json",
            "polyfills": "src/polyfills.ts",
            "assets": [
              "src/assets",
              "src/favicon.ico",
              "src/marker-icon.png",
              "src/marker-icon-2x.png"
            ],
            "styles": [
              "./node_modules/bootstrap/dist/css/bootstrap.min.css",
              "./node_modules/ngx-bootstrap/datepicker/bs-datepicker.css",
              "node_modules/bootstrap/scss/bootstrap.scss",
              "node_modules/font-awesome-scss/scss/font-awesome.scss",
              "src/assets/images/zommer/leaflet/dist/leaflet.css",
              "src/assets/images/zommer/leaflet-draw-toolbar/dist/leaflet.draw-toolbar.css",
              "src/assets/images/zommer/leaflet-toolbar/dist/leaflet.toolbar.css",
              "src/assets/images/zommer/leaflet-draw/dist/leaflet.draw-src.css",
              "src/scss/style.scss"
            ],
            "scripts": [
              "src/assets/images/zommer/jquery.min.js",
              "src/assets/images/zommer/bootstrap.min.js",
              "src/assets/images/zommer/leaflet/dist/leaflet-src.js",
              "src/assets/images/zommer/leaflet/dist/leaflet.rotatedMarker.js",
              "src/assets/images/zommer/leaflet-toolbar/dist/leaflet.toolbar-src.js",
              "src/assets/images/zommer/leaflet-draw/dist/leaflet.draw-src.js",
              "src/assets/images/zommer/leaflet-draw-toolbar/dist/leaflet.draw-toolbar.js",
              "src/assets/images/zommer/color.js",
              "src/assets/images/zommer/pdf.js",
              "src/assets/images/zommer/pdf.worker.js",
              "src/assets/images/zommer/leafletfunction.js"
            ]
          },
          "configurations": {
            "prod": {
              "fileReplacements": [
                {
                  "replace": "src/environments/environment.ts",
                  "with": "src/environments/environment.prod.ts"
                }
              ]
            },
            "production": {
              "optimization": true,
              "outputHashing": "all",
              "sourceMap": false,
              "extractCss": true,
              "namedChunks": false,
              "aot": true,
              "extractLicenses": true,
              "vendorChunk": false,
              "buildOptimizer": true
            }
          }
        },
        "serve": {
          "builder": "@angular-devkit/build-angular:dev-server",
          "options": {
            "browserTarget": "mega-able:build"
          },
          "configurations": {
            "prod": {
              "browserTarget": "mega-able:build:prod"
            },
            "production": {
              "browserTarget": "mega-able:build:production"
            }
          }
        },
        "extract-i18n": {
          "builder": "@angular-devkit/build-angular:extract-i18n",
          "options": {
            "browserTarget": "mega-able:build"
          }
        },
        "test": {
          "builder": "@angular-devkit/build-angular:karma",
          "options": {
            "main": "src/test.ts",
            "karmaConfig": "./karma.conf.js",
            "polyfills": "src/polyfills.ts",
            "tsConfig": "src/tsconfig.spec.json",
            "scripts": [
              "src/assets/images/zommer/jquery.min.js",
              "src/assets/images/zommer/bootstrap.min.js",
              "src/assets/images/zommer/leaflet/dist/leaflet-src.js",
              "src/assets/images/zommer/leaflet/dist/leaflet.rotatedMarker.js",
              "src/assets/images/zommer/leaflet-toolbar/dist/leaflet.toolbar-src.js",
              "src/assets/images/zommer/leaflet-draw/dist/leaflet.draw-src.js",
              "src/assets/images/zommer/leaflet-draw-toolbar/dist/leaflet.draw-toolbar.js",
              "src/assets/images/zommer/color.js",
              "src/assets/images/zommer/pdf.js",
              "src/assets/images/zommer/pdf.worker.js",
              "src/assets/images/zommer/leafletfunction.js"
            ],
            "styles": [
              "./node_modules/bootstrap/dist/css/bootstrap.min.css",
              "./node_modules/ngx-bootstrap/datepicker/bs-datepicker.css",
              "node_modules/bootstrap/scss/bootstrap.scss",
              "node_modules/font-awesome-scss/scss/font-awesome.scss",
              "src/assets/images/zommer/leaflet/dist/leaflet.css",
              "src/assets/images/zommer/leaflet-draw-toolbar/dist/leaflet.draw-toolbar.css",
              "src/assets/images/zommer/leaflet-toolbar/dist/leaflet.toolbar.css",
              "src/assets/images/zommer/leaflet-draw/dist/leaflet.draw-src.css",
              "src/scss/style.scss"
            ],
            "assets": [
              "src/assets",
              "src/favicon.ico",
              "src/marker-icon.png",
              "src/marker-icon-2x.png"
            ]
          }
        },
        "lint": {
          "builder": "@angular-devkit/build-angular:tslint",
          "options": {
            "tsConfig": [
              "src/tsconfig.app.json",
              "src/tsconfig.spec.json"
            ],
            "exclude": [
              "**/node_modules/**"
            ]
          }
        }
      }
    },
    "mega-able-e2e": {
      "root": "e2e",
      "sourceRoot": "e2e",
      "projectType": "application",
      "architect": {
        "e2e": {
          "builder": "@angular-devkit/build-angular:protractor",
          "options": {
            "protractorConfig": "./protractor.conf.js",
            "devServerTarget": "mega-able:serve"
          }
        },
        "lint": {
          "builder": "@angular-devkit/build-angular:tslint",
          "options": {
            "tsConfig": [
              "e2e/tsconfig.e2e.json"
            ],
            "exclude": [
              "**/node_modules/**"
            ]
          }
        }
      }
    }
  },
  "defaultProject": "mega-able",
  "schematics": {
    "@schematics/angular:component": {
      "prefix": "app",
      "styleext": "scss"
    },
    "@schematics/angular:directive": {
      "prefix": "app"
    }
  }
}

下面是我在谷歌搜索的基础上尝试过的所有事情。除非另外指定,否则所有命令都是从Git Bash窗口运行的:

  1. npm安装-g @转角/cli
  2. npm安装@转角/cli
  3. ng update @角/cli
  4. ng更新
  5. 更新“角/cli”角/核心
  6. 吴建

有关NgModule元数据的同样问题仍然存在。接下来,我尝试了以下几种方法:

  1. 国家预防机制罢免webpack
  2. npm安装-保存-dev@转角/cli@最新
  3. npm缓存干净的-force
  4. npm安装
  5. npm安装-保存-dev@转角/cli@最新
  6. 吴建

问题持续存在。下一步:

  1. 手动删除node_modules文件夹
  2. npm安装
  3. 吴建

问题持续存在。下一步:

  1. npm i -g @转角/cli最新
  2. 手动删除node_modules文件夹
  3. npm缓存清除-force
  4. npm缓存验证
  5. npm安装
  6. npm卸载webpack
  7. npm安装-保存-开发-保存-精确@角/cli@最新
  8. 吴建

问题持续存在。下一步:

  1. 手动删除node_modules文件夹
  2. 手动删除包-lock.json文件
  3. npm安装
  4. 吴建

问题持续存在。下一步:

  1. 国家预防机制罢免webpack
  2. npm安装-保存-dev@转角/cli@最新
  3. 吴建

问题持续存在。下一步:

  1. npm缓存干净的-force
  2. npm安装
  3. npm安装-保存-dev@转角/cli@最新
  4. 吴建

问题持续存在。下一步:

  1. 手动删除node_modules文件夹
  2. 手动删除包-lock.json文件
  3. npm缓存干净的-force
  4. npm安装
  5. npm安装-保存-dev@转角/cli@最新

问题持续存在。下一步:

  1. 在Visual代码中打开项目
  2. 在终端窗口中运行ng
  3. 确认编译错误
  4. 打开app.component.ts文件
  5. 添加一个空白,删除它,并保存
  6. 项目自动重新编译
  7. http://localhost:4200成功访问站点
  8. 封闭代码
  9. 从Git Bash窗口运行服务
  10. 项目编译失败
  11. 重新打开代码
  12. 从终端窗口运行ng服务-错误持久化
  13. 解析app.component.ts文件
  14. http://localhost:4200成功访问该站点
  15. 重新启动Visual代码
  16. 从Visual中的终端窗口运行ng生成-返回错误
  17. 解析app.component.ts文件
  18. 重新运行生成命令-错误持久化

在这一点上,我已经不知所措了,开发团队将在周二休假,所以任何帮助或建议都会受到极大的感谢,因为我受到了一些时间的限制。提前感谢您的帮助。

EN

回答 6

Stack Overflow用户

发布于 2019-03-24 03:07:04

我想你已经读过这篇文章了:https://github.com/angular/angular-cli/issues/8798

如果没有,请阅读并注意TS也手动修改了package.json文件以解决他的问题。

由于我们还没有在您的构建中看到实际的错误消息,所以我们无法推断该问题是否与链接中的问题相同。因此,我想让你们解决你们的问题是做以下几件事:

  1. 删除npm_modules文件夹
  2. 将package.json文件移动到备份文件夹中(以防我们需要它回来)--因此在您的项目文件夹中不应该存在这个文件,因为在执行接下来的步骤时它将生成。
  3. 安装npm吗?
  4. 做ng构建
  5. 服务,服务

在完成上述操作之后,或者如果您再次使用,我建议查看旧的package.json文件和新的package.json文件之间的区别,并让我们知道您观察到了什么,因为回馈总是很好的。

票数 3
EN

Stack Overflow用户

发布于 2020-05-26 19:04:25

如果这对tsconfig.app.json中的人有帮助(或者在您定义tsconfig设置的任何地方),这个角编译器选项(当设置为true时)会导致各种元数据失败,即使NgModule元数据中没有直接引用文件(只要在index.ts中导入一个文件就够了)。

单独的文件/类型可以用// @dynamic注释填充,或者.您可以检查以确保strictMetadataEmit设置为false:

tsconfig.json:

代码语言:javascript
复制
"angularCompilerOptions": {
    "strictMetadataEmit": false
}

在我的例子中,这在某个时候被设置为真,所以对于与模块防御无关的类来说,角在元数据上失败了。将其设置为false (这是默认的,如这里所指定的:https://angular.io/guide/angular-compiler-options),解决了这个问题。

票数 3
EN

Stack Overflow用户

发布于 2022-06-22 14:23:16

在我的例子中,我可能有一个依赖错误。我试过此链接的所有东西,但都没有用。在从6.2更新到7之后,我必须完成以下操作才能成功构建:

  1. 删除节点模块文件夹。
  2. 运行以下命令:cmd /C "set "NG_DISABLE_VERSION_CHECK=1" && npx @angular/cli@7 update @angular/cli@7 @angular/core@7" --force。(基本相同的更新命令来自官方的角度更新指南,但带有--force标志。)
  3. 运行以下命令:npm install --legacy-peer-deps。如果失败,您可能不得不再次使用--force标志。

环境: Windows 10,Node 10.9,Nvm 1.1.9,

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/55320181

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档