解决 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()
相关推荐
w***Q3502 分钟前
Vue打包
前端·javascript·vue.js
有事没事实验室7 分钟前
router-link的custom模式
前端·javascript·vue.js
常乐我净61614 分钟前
十、路由和导航
前端
Tonychen15 分钟前
TypeScript 里 infer 常见用法
前端·typescript
米诺zuo16 分钟前
MUI sx prop 中的响应式适配
前端
周尛先森17 分钟前
都React 19了,他到底带来了什么?
前端
洞窝技术22 分钟前
一键屏蔽某国IP访问实战
前端·nginx·node.js
fruge34 分钟前
前端自动化脚本:用 Node.js 写批量处理工具(图片压缩、文件重命名)
前端·node.js·自动化
Jolyne_1 小时前
antd Image base64缓存 + loading 态优化方案
前端
BINGCHN1 小时前
NSSCTF每日一练 SWPUCTF2021 include--web
android·前端·android studio