配置:macOS High Sierra,版本10.13.2,节点:v8.1.2 npm:5.0.3 当我在angularjs项目中运行npm start时,我得到这个错误:

ERROR in Cannot find module 'node-sass'

然后我运行:

npm i node-sass

现在我得到这个错误:

gyp: No Xcode or CLT version detected!
gyp ERR! configure error 
gyp ERR! stack Error: `gyp` failed with exit code: 1

为什么npm不安装node-sass?如何安装node-sass?


当前回答

Run:

npm rebuild node-sass --force              

它会工作得很好。

其他回答

下面是解决方案:

sudo npm install --save-dev  --unsafe-perm node-sass

享受吧!

编辑以解释选项(来自评论):

——save-dev被使用,这样你的应用程序就能在本地node_modules中找到这个模块。——save-dev将package添加到package.json中的devDependencies中。——不安全——perm用于以root身份运行安装脚本。为了避免sudo,请改用nvm。——不安全——烫发真的不需要,因为已经提到了sudo。因此,该命令基本上严格限制脚本以不惜任何代价安装node-sass。

我在Angular中安装依赖时也犯了同样的错误。我尝试了前面提到的技术,但在删除包锁之前,它们都不起作用。json,它是之前运行Node v11时创建的。

现在我使用的是Node v12,这就是我如何得到解决的。

我重复一遍,如果你有包锁。Json删除它,文件,然后安装依赖。

NPM install node-sass将在大多数情况下完成这项工作,因为它将添加缺失的sass NPM依赖模块不存在,或者它将覆盖以前崩溃的版本。

对于Mac用户,在上述命令前使用sudo。

在Windows机器上,npm rebuild node-sass——force可能对某些用户不起作用,因为它本质上是在说,“请强制npm为我重建sass节点模块”。它将无法工作,因为该模块不存在。

无论何时你在初始安装时进行npm install, sass模块都没有安装,这就是为什么会出现这个问题。

在我的情况下,我还必须执行:

npm install sass-loader

解决问题

如果你跑了

npm install node-sass

它仍然不起作用,记得把权限改为文件夹