Мы находимся в процессе обновления наших репо с Angular 7 до Angular 8 (и в конечном итоге до 9). У нас есть репозиторий Angular, который был только что обновлен до нужной библиотеки Angular 8, и, похоже, все работает нормально и опубликован в виде частного NPM пакета. Наше основное приложение Angular 8 использует библиотеку, но я получаю ошибки модуля для всего в библиотеке:
ERROR in ./src/app/app.module.ts
Module not found: Error: Can't resolve '@my-scope/my-library/a-z-list-legend' in '[local-path]/src/app'
ERROR in ./src/app/app.module.ts
Module not found: Error: Can't resolve '@my-scope/my-library/analytics' in '[local-path]/src/app'
and so on...
Я следовал руководству Angular - Создание библиотек , поэтому Я использую команду: ng build my-library
и publi sh до NPM. Там я не получаю никаких ошибок.
Вот скриншот структуры файла моей библиотеки:
Как примечание, я все еще используя бочки, на которые есть ссылки в моем файле public-api.ts
.
Это то, что устанавливается в node_modules
вместе с каждым из комплектов версий ES:
И пример импорта модуля в app.module.ts
выглядит следующим образом:
import { AZListLegendModule } from '@my-scope/my-library/a-z-list-legend';
На данный момент я немного растерялся и не уверен, что это проблема с библиотека или приложение потребителя. Спасибо за любую помощь.
ОБНОВЛЕНИЕ:
Вот сокращенное package.json
, используемое в обоих репозиториях:
{
"dependencies": {
"@angular/animations": "~8.2.0",
"@angular/cdk": "~8.2.0",
"@angular/common": "~8.2.0",
"@angular/compiler": "~8.2.0",
"@angular/core": "~8.2.0",
"@angular/flex-layout": "8.0.0-beta.27",
"@angular/forms": "~8.2.0",
"@angular/material": "~8.2.0",
"@angular/material-moment-adapter": "~8.2.0",
"@angular/platform-browser": "~8.2.0",
"@angular/platform-browser-dynamic": "~8.2.0",
"@angular/router": "~8.2.0",
"rxjs": "~6.4.0",
"tslib": "^1.10.0",
"zone.js": "~0.9.1"
},
"devDependencies": {
"@angular-devkit/build-angular": "~0.802.2",
"@angular/cli": "~8.2.2",
"@angular/compiler-cli": "~8.2.0",
"@angular/language-service": "~8.2.0",
"@types/node": "~8.9.4",
"codelyzer": "^5.0.0",
"jasmine-core": "~3.4.0",
"jasmine-spec-reporter": "~4.2.1",
"karma": "~4.1.0",
"karma-chrome-launcher": "~2.2.0",
"karma-coverage-istanbul-reporter": "~2.0.1",
"karma-jasmine": "~2.0.1",
"karma-jasmine-html-reporter": "^1.4.0",
"typescript": "~3.5.3"
}
}
И ng --version
dump:
_ _ ____ _ ___
/ \ _ __ __ _ _ _| | __ _ _ __ / ___| | |_ _|
/ △ \ | '_ \ / _` | | | | |/ _` | '__| | | | | | |
/ ___ \| | | | (_| | |_| | | (_| | | | |___| |___ | |
/_/ \_\_| |_|\__, |\__,_|_|\__,_|_| \____|_____|___|
|___/
Angular CLI: 8.2.2
Node: 10.17.0
OS: darwin x64
Angular: 8.2.14
... animations, common, compiler, compiler-cli, core, forms
... language-service, platform-browser, platform-browser-dynamic
... router
Package Version
------------------------------------------------------------
@angular-devkit/architect 0.802.2
@angular-devkit/build-angular 0.802.2
@angular-devkit/build-optimizer 0.802.2
@angular-devkit/build-webpack 0.802.2
@angular-devkit/core 8.2.2
@angular-devkit/schematics 8.2.2
@angular/cdk 8.2.3
@angular/cli 8.2.2
@angular/flex-layout 8.0.0-beta.27
@angular/material 8.2.3
@angular/material-moment-adapter 8.2.3
@ngtools/webpack 8.2.2
@schematics/angular 8.2.2
@schematics/update 0.802.2
rxjs 6.4.0
typescript 3.5.3
webpack 4.38.0
ОБНОВЛЕНИЕ 2:
Похоже, Angular 8 Библиотеки не поддерживают глубокий импорт. Изменение всего моего импорта на @my-scope/my-library
, кажется, работает.