坑爹的create-react-app 命令,把我害惨了!进来听我的复仇计划

前言

最近在搭建react项目时,使用了npx create-react-app xxx 来创建一个react项目,结果发现和我以前的项目组的react项目的css module规则不一致,排查了一个小时无果,还发了沸点求助JYM,但仍没有得到想要的答案,于是我继续狠狠深入研究了一下

具体不同点

经常性的,我们在react项目中会使用.module.css的引入方式在.jsx/js/tsx文件中引入样式 .module.css文件长这样 (@apply 和原子化写法是tailwindcss写法)

而.jsx文件通常是这样 我们对每个类名的使用都需要借助一个styles对象才能使用

并且这种使用方式会使所有类名都加上哈希后缀

而当我回想起来上家公司的react项目中不需要这样做 上家公司的.jsx文件是这样使用的

只需要对最顶级的节点的类名用styles包一下,这样就能正常的使用,写起来很方便,同时组件顶层节点还包含了正常的类名哈希,使得类名不会有污染,做到组件间的隔离,页面表现如下

于是我开始思考这其中的原因,经过几个小时的查阅资料和AI对话,我总算找出了问题所在

问题所在

实际上是css-loader的配置问题,由于我是使用的create-react-app脚手架创建的项目,真是坑死我了!!!他其实自带了webpack的配置,也帮我们预设好了css-loader的配置,使用的modules模式是local,而我们需要使用npm run eject命令,才能把那些预设配置文件显示在我们的本地文件夹里,eject后,会多出几个文件夹

然后只需要把webpack.config.js文件中的css-loader的modules的mode配置项改成global,如下: 这样就能实现我上家公司项目的那个效果,只是一行配置问题,我排查了近三个小时,弄明白之后自己都想笑,因为css-loader的文档写的实在是不太详细,调试了很久才彻底弄懂。

难怪我上家公司的react构建工具没有选择webpack,而是使用vite创建的react项目,我和前端同事沟通,发现还有很多craco构建的react项目,都避开了繁琐的webpack配置,实在是蚌埠住了,也是又学到了。知道的大佬们见笑了。轻喷。

相关推荐
一舍予41 分钟前
八股文-js篇
开发语言·前端·javascript
鸡鸭扣1 小时前
DRF/Django+Vue项目线上部署:腾讯云+Centos7.6(github的SSH认证)
前端·vue.js·python·django·腾讯云·drf
龙井茶Sky1 小时前
验证码与登录过程逻辑学习总结
前端·登录·验证码
大刘讲IT2 小时前
IT/OT 融合架构下的工业控制系统安全攻防实战研究
经验分享·安全·web安全·架构·制造
中杯可乐多加冰2 小时前
【解决方案】CloudFront VPC Origins 实践流程深入解析 —— 安全高效架构的实战之道
安全·架构·安全架构·vpc·cloudfront
喵叔哟2 小时前
17.【.NET 8 实战--孢子记账--从单体到微服务--转向微服务】--微服务基础工具与技术--loki
微服务·架构·.net
程序员JerrySUN2 小时前
驱动开发硬核特训 · Day 30(下篇): 深入解析 lm48100q I2C 音频编解码器驱动模型(基于 i.MX8MP)
linux·驱动开发·架构·音视频
2401_831943322 小时前
Element Plus对话框(ElDialog)全面指南:打造灵活弹窗交互
前端·vue.js·交互
strongwyy3 小时前
DA14585墨水屏学习(2)
前端·javascript·学习
好青崧3 小时前
冒泡排序的原理
前端