webpack 老项目升级记录:从 node-sass 限制的的 node v8 提升至支持 ^node v22

ops/2024/10/25 14:13:39/

老项目简介

技术框架

几个阶段

第一步:vue2 升级到最新

第一步:升级 vue2 至最新版本,截止到目前(2024-10-21),最高的 vue 版本是 "vue": "^2.7.16"

这一步会比较丝滑,2版本兼容的挺好的

第二步:寻找项目只能在 Node 低版本下运行的原因

什么叫版本只能在低版本运行的原因呢:举个例子,比方说我的项目必须用 Node 8 版本启动,其他版本就不行

第二步:寻找 node 版本锁死的原因:node-sass!!!

这个依赖包版本是跟 node 版本强绑定的 ,具体可以看一下这个

在这里插入图片描述

所以我改成了 sass ,也叫 dart-sass

在这里插入图片描述
这一步需要修改源码了!

因为 sass 只支持 ::v-deep,而 node-sass 同时支持/deep/::v-deep

所以,可以全局搜索 /deep/::v-deep,这一步可能会改很多的文件!记得修改完之后跑一下试试!

在这里插入图片描述

此时,我们的 node 版本大概可以支持到 node V16,这个的限制是因为 webpack4

根据 Webpack 4 的官方文档和社区反馈,Webpack 4 支持的最高 Node.js 版本是 14.x。
建议使用 Node.js 14.x 版本以获得最佳的兼容性和性能。

webpack__vite_36">替换 webpack 为 vite

这一步的工程量也是挺大的,大概有如下几点

  • 安装 vite

    npm install –save vite
    
  • 安装你项目语言的插件(例如vue2,vue3,react 等),我的是 vue2

    npm install –save @vitejs/plugin-vue2
    import vue2 from "@vitejs/plugin-vue2";
    
  • 修改 package.json 里的命令

    {"scripts": {"dev": "vite", // 启动开发服务器,别名:`vite dev`,`vite serve`"build": "vite build", // 为生产环境构建产物"preview": "vite preview" // 本地预览生产构建产物}
    }
    
  • 项目根目录下,新建一个 vite.config.ts

    // vite.config.js
    import { defineConfig } from 'vite'
    import vue2 from "@vitejs/plugin-vue2";
    export default defineConfig({plugins: [vue2(),],
    })
    
  • 还要新建一个 .env 的文件,用于存放 process 的变量,这里的变量我是在 axios 拦截器里用的在这里插入图片描述

    VITE_BASE_URL= "后端地址"
    
  • 还要改一下项目根目录的 index.html 的入口文件,具体参考这个官方文档

    <!-- index.html -->
    <!DOCTYPE html>
    <html lang="en">
    <head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>wukong</title><link rel="icon" href="/favicon.ico">
    </head>
    <body><div id="app"></div><script type="module" src="/src/main.js"></script>
    </body>
    </html>
    
  • vite 运行之后会报错,是因为一些组件在引入的时候没有写 .vue,添加 extensionsvite.config
    在这里插入图片描述

    resolve: {alias: {"@": path.resolve(__dirname, "src"),},extensions: [".js", ".json", ".ts", ".jsx", ".tsx", ".vue"], // 添加 .vue 扩展名},
    
  • … 大概就是这么多,肯定会遇到其他问题的,根据自己的项目改就好

切换完 vite 之后,node版本就可以切得高一点来试试了,我的是 v22.9.0
在这里插入图片描述

sass_wehttpsiblogcsdnimgcndirecte83fd4c5d685417086569d98bbbc1312png_121">sass 终端提示报错(未解决)(we

这个原因是 sass 的问题,虽然给了配置字段,但是不好使,看着闹心的话暂时没啥办法,容我再研究研究

1. https://sass-lang.com/blog/import-is-deprecated/#built-in-functions
2. https://stackoverflow.com/questions/78997907/the-legacy-js-api-is-deprecated-and-will-be-removed-in-dart-sass-2-0-0

在这里插入图片描述


http://www.ppmy.cn/ops/128356.html

相关文章

【小白学机器学习16】 概率论的世界观2: 从正态分布去认识世界

目录 1 从正态分布说起 1.1 正态分布的定义 1.2 正态分布的名字 1.3 正态分布的广泛&#xff0c;和基础性 2 正态分布的公式和图形 2.1 正态分布 2.2 标准正态分布 3 正态分布的认识的3个层次 3.1 第1层次&#xff1a;个体的某个属性的样本值&#xff0c;服从正态分布…

neo4j 中日期时间 时间戳处理

### 使用指定格式&#xff08;默认ISO&#xff09;和指定时区&#xff08;默认当前TZ&#xff09;&#xff0c;使用指定单位&#xff08;默认ms&#xff09;获取时间值的字符串表示形式&#xff08;可选&#xff09; 测试 return apoc.date.format(1729380807273,(ms),(yyyy-…

当遇到 502 错误(Bad Gateway)怎么办

很多安装雷池社区版的时候&#xff0c;配置完成&#xff0c;访问的时候可能会遇到当前问题&#xff0c;如何解决呢&#xff1f; 客户端&#xff0c;浏览器排查 1.刷新页面和清除缓存 首先尝试刷新页面&#xff0c;因为有时候 502 错误可能是由于网络临时波动导致服务器无法连…

基于neo4j的疫情信息管理系统

你是否想过&#xff0c;一个能清晰展示疫情传播路径和患者关系的系统有多强大&#xff1f;今天&#xff0c;就来介绍一套专为疫情信息设计的知识图谱管理系统&#xff0c;它利用Neo4j图数据库构建&#xff0c;帮助你轻松掌握疫情动态和患者之间的潜在联系&#xff0c;让疫情防控…

Java中的LinkedList和ArrayList以及HashMap和TreeMap

在Java的集合框架中&#xff0c;LinkedList和ArrayList都是用来存储一组对象的容器&#xff0c;但它们在内部实现、性能特点等方面存在着一些差异。 ## 一、内部实现 1. **ArrayList** - ArrayList是基于数组实现的动态数组。它在内存中是一块连续的存储空间。当创建ArrayL…

移动开发(五):.NET MAUI中自定义主题设置

目录 一、.NET MAUI主题设置原理 二、.NET MAUI主题设置案例 2.1 创建主题文件 2.2 修改App.xaml 文件 2.3 设置默认主题的三种方式 2.4 通过按钮切换主题 三、.NET MAUI主题设置技巧 四、总结 今天给大家分享.NET MAUI应用中如何自定义主题&#xff0c;提升APP本身个性…

数据结构——树——二叉树——大小堆

目录 1>>导言 2>>树 2.1>>树的相关术语 2.2>>树的表示和应用场景 3>>二叉树 3.1>>完全二叉树 3.2>>大小根堆 4>>结语 1>>导言 上篇小编将队列的内容给大家讲完了&#xff0c;这篇要步入新的篇章&#xff0c;请宝…

Nginx服务器反向代理MinIO配置

文章目录 配置请求代理到该域名的根目录请求代理到该域名的非根目录 参考网址 配置 请求代理到该域名的根目录 # 代理minio 上传server {listen 80;listen [::]:80;server_name minio.example.net;# 允许在HTTP头中使用特殊字符ignore_invalid_headers off;# 禁用代理…