Angular 8 - Ленивые загрузочные модули: Ошибка TS1323: Динамический импорт поддерживается только в том случае, если флаг --module установлен на 'commonjs' или 'esNext'

Когда я обновил Angular с 7 до Angular 8, я получил ошибку при отложенной загрузке модулей

Я попробовал варианты, которые есть в угловом руководстве по обновлению

Сделаны следующие изменения:

До

    loadChildren: '../feature/path/sample- 
                         tage.module#SameTagModule'

После

   loadChildren: () => import('../feature/path/sample- 
                      tags.module').then(m => m.CreateLinksModule)

ошибка TS1323: динамический импорт поддерживается только в том случае, если флаг --module имеет значение "commonjs" или "esNext".

Ответ 1

Вы используете динамический импорт, поэтому вы должны изменить свой tsconfig.json следующим образом, чтобы направить свой код в модуль esnext

{
  "compileOnSave": false,
  "compilerOptions": {
    "baseUrl": "./",
    "outDir": "./dist/out-tsc",
    "sourceMap": true,
    "declaration": false,
    "module": "esnext", // add this line
    "moduleResolution": "node",
    "emitDecoratorMetadata": true,
    "experimentalDecorators": true,
    "importHelpers": true,
    "target": "es2015",
    "typeRoots": [
      "node_modules/@types"
    ],
    "lib": [
      "es2018",
      "dom"
    ]
  }
}

Также убедитесь, что tsconfig.app.json не имеет модуля и целевого конфига примерно так

{
  "extends": "./tsconfig.json",
  "compilerOptions": {
    "outDir": "./out-tsc/app",
    "types": []
  },
  "include": [
    "src/**/*.ts"
  ],
  "exclude": [
    "src/test.ts",
    "src/**/*.spec.ts"
  ]
}

Ответ 2

Просто добавив @Tony anwser, вам также может понадобиться сделать то же самое (смените на "module": "esnext") в файле tsconfig.app.json. В моем случае tsconfig.json уже использовал esnext в качестве модуля, но tsconfig.app.json все еще использовал es2015, и это вызвало эту ошибку.