Angular Storybook - WebpackOptionsValidationError:Webpack 已使用与 API 模式不匹配的配置对象进行初始化
Posted
技术标签:
【中文标题】Angular Storybook - WebpackOptionsValidationError:Webpack 已使用与 API 模式不匹配的配置对象进行初始化【英文标题】:Angular Storybook - WebpackOptionsValidationError: Webpack has been initialised using a configuration object that does not match the API schema 【发布时间】:2021-11-08 13:05:05 【问题描述】:我已将 Angular 从 11
更新为 12
,并且我还在我的 package.json
中将所有软件包更新为最新版本:
"name": "poc-architecture-angular",
"version": "0.0.0",
"scripts":
"ng": "ng",
"start": "ng serve --host 0.0.0.0 --port 4200",
"build": "NODE_ENV=production ng build --prod",
"build:dev": "NODE_ENV=production ng build --source-map=true --prod",
"build:local": "ng build --watch --output-path /usr/share/nginx/html && tar -zcvf archive.tar.gz dist/prod/*",
"test": "ng test",
"test:coverage": "ng test --no-watch --code-coverage --browsers ChromeHeadlessNoSandbox",
"lint": "ng lint",
"e2e": "ng e2e",
"stylelint": "stylelint --fix \"src/**/*.scss\" --config .stylelintrc.json",
"stylelint:diff": "stylelint \"src/**/*scss\" --config .stylelintrc.json",
"format": "prettier --write \"src/app/**/*.ts,html,scss\"",
"format:diff": "prettier --list-different \"src/app/**/*.ts,html,scss\"",
"analize": "ng build --prod --stats-json && node_modules/.bin/webpack --json | webpack-bundle-analyzer ./dist/poc-architecture-angular/stats.json",
"compodoc": "./node_modules/.bin/compodoc -p ./tsconfig.base.json -w -s --language=it-IT -r 8081",
"docs:json": "compodoc -p ./tsconfig.json -e json -d .",
"storybook": "npm run docs:json && start-storybook -p 9001 --quiet -c .storybook",
"build-storybook": "npm run docs:json && build-storybook",
"cypress:open-local": "cypress open --config baseUrl=http://localhost:4200",
"cypress:run-local": "cypress run --config baseUrl=http://localhost:4200",
"sonar": "sonar-scanner"
,
"husky":
"hooks":
"pre-commit": "lint-staged"
,
"lint-staged":
"src/app/**/*.ts,html,scss": [
"prettier --write"
]
,
"exports":
"./": "./*"
,
"private": true,
"dependencies":
"@angular/animations": "~12.2.5",
"@angular/cdk": "^12.2.5",
"@angular/common": "~12.2.5",
"@angular/compiler": "^12.2.5",
"@angular/core": "~12.2.5",
"@angular/forms": "~12.2.5",
"@angular/material": "^12.2.5",
"@angular/platform-browser": "~12.2.5",
"@angular/platform-browser-dynamic": "~12.2.5",
"@angular/router": "~12.2.5",
"@fullcalendar/angular": "^5.5.0",
"@fullcalendar/core": "^5.5.1",
"@fullcalendar/daygrid": "^5.5.0",
"@fullcalendar/interaction": "^5.5.0",
"@ng-select/ng-select": "^7.2.0",
"@ngrx/effects": "^12.4.0",
"@ngrx/router-store": "^12.4.0",
"@ngrx/store": "^12.4.0",
"@ngrx/store-devtools": "^12.4.0",
"@storybook/preset-scss": "^1.0.3",
"chart.js": "^3.5.1",
"filesize": "^8.0.0",
"hammerjs": "^2.0.8",
"lodash-es": "^4.17.20",
"luxon": "^2.0.2",
"mammoth": "^1.4.16",
"moment": "^2.29.1",
"ng2-pdf-viewer": "^7.0.1",
"ngrx-store-localstorage": "^12.0.1",
"ngx-cookie-service": "^12.0.3",
"ngx-infinite-scroll": "^10.0.1",
"ngx-webstorage": "^8.0.0",
"rxjs": "~6.6.0",
"tslib": "^2.0.0",
"xlsx": "^0.17.1",
"zone.js": "~0.11.3"
,
"devDependencies":
"@angular-devkit/build-angular": "^12.2.5",
"@angular/cli": "^12.2.5",
"@angular/compiler-cli": "^12.2.5",
"@babel/core": "^7.13.10",
"@compodoc/compodoc": "^1.1.11",
"@ngrx/schematics": "^12.4.0",
"@storybook/addon-actions": "^6.1.21",
"@storybook/addon-backgrounds": "^6.1.21",
"@storybook/addon-docs": "^6.1.21",
"@storybook/addon-knobs": "^6.1.21",
"@storybook/addon-links": "^6.1.21",
"@storybook/addon-storysource": "^6.1.21",
"@storybook/addon-viewport": "^6.1.21",
"@storybook/angular": "^6.1.21",
"@types/faker": "^5.1.7",
"@types/fs-extra": "^9.0.12",
"@types/jasmine": "^3.5.14",
"@types/jasminewd2": "~2.0.3",
"@types/lodash": "^4.14.168",
"@types/luxon": "^2.0.3",
"@types/node": "^16.9.1",
"autoprefixer": "^10.0.1",
"babel-loader": "^8.2.2",
"codelyzer": "^6.0.0",
"css-loader": "^6.2.0",
"cypress": "^8.3.1",
"faker": "^5.1.0",
"husky": "^7.0.2",
"jasmine-core": "~3.9.0",
"jasmine-spec-reporter": "~7.0.0",
"karma": "~6.3.4",
"karma-chrome-launcher": "~3.1.0",
"karma-coverage": "~2.0.3",
"karma-jasmine": "~4.0.0",
"karma-jasmine-html-reporter": "^1.5.0",
"lint-staged": "^11.1.2",
"ng-packagr": "^12.2.1",
"postcss": "^8.1.0",
"postcss-loader": "^6.1.1",
"prettier": "^2.2.1",
"protractor": "~7.0.0",
"puppeteer": "~10.2.0",
"sass-loader": "^12.1.0",
"sonarqube-scanner": "2.8.1",
"style-loader": "^3.2.1",
"stylelint": "^13.6.1",
"stylelint-config-sass-guidelines": "^8.0.0",
"stylelint-config-standard": "^22.0.0",
"stylelint-order": "^4.1.0",
"stylelint-scss": "^3.18.0",
"tailwindcss": "^2.2.6",
"tailwindcss-multi-column": "^1.0.2",
"ts-node": "~10.2.1",
"tslint": "~6.1.0",
"tslint-config-prettier": "^1.18.0",
"typescript": "~4.3.5",
"webpack-bundle-analyzer": "^4.4.2",
"webpack-cli": "^4.8.0"
我在这个项目中也有Storybook
用于Angular
,当我运行npm-run-storybook
时出现此错误:
info => Loading angular-cli config
info => Using angular project "poc-architecture-angular:build" for configuring Storybook
info => Using angular-cli webpack config
info => Using default Webpack4 setup
ERR! WebpackOptionsValidationError: Invalid configuration object. Webpack has been initialised using a configuration object that does not match the API schema.
ERR! - configuration.module.rules[4].rules[0].oneOf[0].type should be one of these:
ERR! "javascript/auto" | "javascript/dynamic" | "javascript/esm" | "json" | "webassembly/experimental"
ERR! -> Module type to use for the module
ERR! at webpack (/home/andrea/workspace/eolo_master/web/node_modules/@storybook/builder-webpack4/node_modules/webpack/lib/webpack.js:31:9)
ERR! at Object.start (/home/andrea/workspace/eolo_master/web/node_modules/@storybook/builder-webpack4/dist/cjs/index.js:96:18)
ERR! at async Promise.all (index 0)
ERR! at async storybookDevServer (/home/andrea/workspace/eolo_master/web/node_modules/@storybook/core-server/dist/cjs/dev-server.js:123:28)
ERR! at async buildDevStandalone (/home/andrea/workspace/eolo_master/web/node_modules/@storybook/core-server/dist/cjs/build-dev.js:112:31)
ERR! at async Object.buildDev (/home/andrea/workspace/eolo_master/web/node_modules/@storybook/core-server/dist/cjs/build-dev.js:154:5)
ERR! WebpackOptionsValidationError: Invalid configuration object. Webpack has been initialised using a configuration object that does not match the API schema.
ERR! - configuration.module.rules[4].rules[0].oneOf[0].type should be one of these:
ERR! "javascript/auto" | "javascript/dynamic" | "javascript/esm" | "json" | "webassembly/experimental"
ERR! -> Module type to use for the module
ERR! at webpack (/home/andrea/workspace/eolo_master/web/node_modules/@storybook/builder-webpack4/node_modules/webpack/lib/webpack.js:31:9)
ERR! at Object.start (/home/andrea/workspace/eolo_master/web/node_modules/@storybook/builder-webpack4/dist/cjs/index.js:96:18)
ERR! at async Promise.all (index 0)
ERR! at async storybookDevServer (/home/andrea/workspace/eolo_master/web/node_modules/@storybook/core-server/dist/cjs/dev-server.js:123:28)
ERR! at async buildDevStandalone (/home/andrea/workspace/eolo_master/web/node_modules/@storybook/core-server/dist/cjs/build-dev.js:112:31)
ERR! at async Object.buildDev (/home/andrea/workspace/eolo_master/web/node_modules/@storybook/core-server/dist/cjs/build-dev.js:154:5)
我没有webpack config
,只有default config of angular-cli
。
我该如何解决?
【问题讨论】:
【参考方案1】:如此处Github Issue Storybook Angular 12 所示,您并不孤单遇到此错误。
如果我们仔细查看您的错误日志,Storybook
继续使用Webpack4
info => Using angular-cli webpack config
info => Using default Webpack4 setup
但是从现在开始Angular 12 use Wepback 5。
您应该遵循Storybook的升级指南并执行以下步骤
npm install @storybook/builder-webpack5@next @storybook/manager-webpack5@next --save-dev
然后编辑您的 .storybook/main.js 配置:
module.exports = 核心: 构建器:'webpack5', , ;
如果这仍然不起作用,请尝试来自vdiaz1130 的以下提示
如果您仍然有问题,请尝试删除您的 node_modules
目录并重新下载依赖项以重新开始。
【讨论】:
最新的“webpack-cli”包版本是4.8.0以上是关于Angular Storybook - WebpackOptionsValidationError:Webpack 已使用与 API 模式不匹配的配置对象进行初始化的主要内容,如果未能解决你的问题,请参考以下文章
如何在 Storybook 中为 Angular 启用样式源映射
Angular 12 的 Storybook 插件 StoryShots
Angular 9 和 Storybook:添加 @angular/localize/init polyfill