错误:安装了几个@ ngtools / webpack包

时间:2018-02-13 19:39:28

标签: angular npm

更新:升级到1.7.0.beta.1修复了问题,但现在我又收到了另一个错误:

ERROR in ./src/main.ts
Module build failed: Error: Angular Compiler was detected but it was an instance of the wrong class.
This likely means you have several @ngtools/webpack packages installed. You can check this with `npm ls @ngtools/webpack`, and then remove the extra copies.
    at Object.ngcLoader (C:\Users\multi\Desktop\portfolioWeb\node_modules\@ngtools\webpack\src\loader.js:458:19)
 @ multi webpack-dev-server/client?http://0.0.0.0:0 ./src/main.ts
ERROR in ./src/polyfills.ts

3 个答案:

答案 0 :(得分:2)

我有同样的错误。在你的项目目录中打开你的package.json并尝试删除安装webpack的行(@ ngtools / webpack) - 它似乎已经安装了新的1.7.0。至少在我的项目中,这解决了这个问题。然后重新安装ang-cli。我不知道是否需要重新安装 - 你可能只是在修改package.json后尝试运行'npm prune' - 这应该删除package.json中不存在的模块。

您可以通过运行推荐的'npm ls @ ngtools / webpack'来检查是否已删除副本 - 它应该只显示您安装的版本而不是之前的版本。

答案 1 :(得分:0)

我删除了文件 package-lock.json 还删除了文件夹 node_modules 中的内容,然后我执行了 npm install 之后, ng serve 命令

答案 2 :(得分:0)

为了从package.json中的依赖项中删除@ngtools/webpack的任何额外软件包,我在升级过程中遇到了这个问题,您将需要使用save标志:

npm uninstall --save webpack

如果您已将软件包安装为“ devDependency”(即使用--save-dev),则--save不会将其从package.json中删除。您需要使用--save-dev来卸载它。 这是上面命令的结果

$ npm ls @ngtools/webpack
angularapp@0.0.0 C:\Apache24\htdocs\angularapp
+-- @angular-devkit/build-angular@0.7.5
| `-- @ngtools/webpack@6.1.5
`-- @ngtools/webpack@6.2.1

$ npm uninstall --save webpack
> node-sass@4.9.3 install C:\Apache24\htdocs\angularapp\node_modules\node-sass
> node scripts/install.js

Cached binary found at C:\Users\user\AppData\Roaming\npm-cache\node-sass\4.9.3\win32-x64-59_binding.node

> node-sass@4.9.3 postinstall C:\Apache24\htdocs\angularapp\node_modules\node-sass
> node scripts/build.js

Binary found at C:\Apache24\htdocs\angularapp\node_modules\node-sass\vendor\win32-x64-59\binding.node
Testing binary
Binary is fine
added 1106 packages in 677.641s

$ npm ls @ngtools/webpack
angularapp@0.0.0 C:\Apache24\htdocs\angularapp
`-- @angular-devkit/build-angular@0.7.5
  `-- @ngtools/webpack@6.1.5