解决 Linux 部署中的文件大小写问题

问题背景

在本地开发环境(Windows/macOS)一切正常,但部署到 Linux 服务器后出现模块加载错误,核心原因是:

Linux 文件系统严格区分大小写

本地开发时 import Component from './MyComponent' 能加载 mycomponent.js

但部署后要求文件名必须完全匹配大小写:MyComponent.js

解决方案

1. ESLint 代码层检测

在编写阶段捕获错误:

javascript 复制代码
// .eslintrc.js
module.exports = {
  settings: {
    "import/resolver": {
      // 指向 Webpack 配置文件 让 ESLint 理解 Webpack 的模块解析规则
      webpack: { config: "./webpack.base.js" } 
    }
  },
  rules: {
    "import/no-unresolved": ["error", { 
      caseSensitive: true // 关键配置
    }]
  }
}

2. Webpack 构建层检测

在编译阶段阻断错误:

javascript 复制代码
// webpack.base.js
const CaseSensitivePathsPlugin = require('case-sensitive-paths-webpack-plugin');

module.exports = {
  plugins: [
    new CaseSensitivePathsPlugin() // 构建时大小写校验
  ]
};

配置要求

工具 安装依赖 核心配置
ESLint eslint-plugin-import eslint-import-resolver-webpack caseSensitive: true
Webpack case-sensitive-paths-webpack-plugin new CaseSensitivePathsPlugin()
相关推荐
灵感__idea12 分钟前
Hello 算法:贪心的世界
前端·javascript·算法
GreenTea2 小时前
一文搞懂Harness Engineering与Meta-Harness
前端·人工智能·后端
killerbasd3 小时前
牧苏苏传 我不装了 4/7
前端·javascript·vue.js
吴声子夜歌3 小时前
ES6——二进制数组详解
前端·ecmascript·es6
码事漫谈4 小时前
手把手带你部署本地模型,让你Token自由(小白专属)
前端·后端
ZC跨境爬虫4 小时前
【爬虫实战对比】Requests vs Scrapy 笔趣阁小说爬虫,从单线程到高效并发的全方位升级
前端·爬虫·scrapy·html
爱上好庆祝4 小时前
svg图片
前端·css·学习·html·css3
王夏奇4 小时前
python中的__all__ 具体用法
java·前端·python
大家的林语冰5 小时前
《前端周刊》尤大开源 Vite+ 全家桶,前端工业革命启动;尤大爆料 Void 云服务新产品,Vite 进军全栈开发;ECMA 源码映射规范......
前端·javascript·vue.js
jiayong235 小时前
第 8 课:开始引入组合式函数
前端·javascript·学习