背景:
项目是基于uniapp的vue2版本,非常老了,项目状况:node版本:: 14.21.3,node-sass版本:"^4.14.1",sass-loader版本:"^9.0.2",本地初始化时node-sass总是安装失败,原因就不多说了,下面说下解决方案:

方案一 : 手动下载包到本地文件夹,适合只是临时启动项目
使用node-sass仓库里的安装问题指南的调试方式
- 项目中 添加以下脚本,执行 preinstall 得到服务器的node版本 ,例如 win32-x64-83
arduino
"scripts":{
"preinstall": "node -p "[process.platform, process.arch, process.versions.modules].join('-')" "
}
- 去下载一个与 服务器的node版本匹配的binging.node 文件

- 离线包下载完之后,放入项目根目录的文件夹里,项目根目录可以新建一个ib文件夹,在根目录里cmd
ini
Set SASS_BINARY_PATH=D:\WorkCode\liblwin32-x64-83_binding.node //PATH=后面是的下载的.node所在的路径
接着
npm rebuild node-sass
npm install node-sass -D
npm instal
- 最后需要去node_moduleslnode-sass里面看看有没有vendor文件夹,没有就自己新建一个,新建一个vendor/win32-x6483(这个文件夹名字按你下载的版本调整,我这里是83),最后把你下载的离线包复制一份进来,重命名为:binding.node就可以啦
方案二(推荐)
使用配置参数的方式,node-sass提供了两种修改他的环境变量方式,一种是参数的形式,一种是.npmrc/.yarnrc配置的方式,为了方便团队协作,选择后者

在package.json中我们能看到以一个配置,此时的binarySite配置已经是404了,所以我们重新配一个可以下载的地址即可

在项目根目录中添加.npmrc/.yarnrc文件,并添加以下代码
ini
sass_binary_site=https://npmmirror.com/mirrors/node-sass/
然后正常安装即可