node-sass安装失败终极解决

背景:

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

方案一 : 手动下载包到本地文件夹,适合只是临时启动项目

使用node-sass仓库里的安装问题指南的调试方式

  1. 项目中 添加以下脚本,执行 preinstall 得到服务器的node版本 ,例如 win32-x64-83
arduino 复制代码
 "scripts":{
   "preinstall": "node -p "[process.platform, process.arch, process.versions.modules].join('-')" "
 }
  1. 去下载一个与 服务器的node版本匹配的binging.node 文件
  1. 离线包下载完之后,放入项目根目录的文件夹里,项目根目录可以新建一个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
  1. 最后需要去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/

然后正常安装即可

相关推荐
Amodoro44 分钟前
nuxt更改页面渲染的html,去除自定义属性、
前端·html·nuxt3·nuxt2·nuxtjs
Wcowin1 小时前
Mkdocs相关插件推荐(原创+合作)
前端·mkdocs
伍哥的传说1 小时前
CSS+JavaScript 禁用浏览器复制功能的几种方法
前端·javascript·css·vue.js·vue·css3·禁用浏览器复制
lichenyang4532 小时前
Axios封装以及添加拦截器
前端·javascript·react.js·typescript
Trust yourself2432 小时前
想把一个easyui的表格<th>改成下拉怎么做
前端·深度学习·easyui
三口吃掉你2 小时前
Web服务器(Tomcat、项目部署)
服务器·前端·tomcat
Trust yourself2432 小时前
在easyui中如何设置自带的弹窗,有输入框
前端·javascript·easyui
烛阴2 小时前
Tile Pattern
前端·webgl
前端工作日常3 小时前
前端基建的幸存者偏差
前端·vue.js·前端框架
Electrolux3 小时前
你敢信,不会点算法没准你赛尔号都玩不明白
前端·后端·算法