react+customize-cra使用less+less-loader时,可能遇到的问题及解决办法

目录

1、先附上各依赖版本和config-overrides.js配置代码,按这个版本和配置就没问题

2、问题(注意:问题顺序没有先后之分哦)

2.1、TypeError: Cannot read property 'tap' of undefined

2.2、No module factory available for dependency type: CssDependency

2.3、ValidationError: CSS Loader Invalid Options

2.3.1、方法一:安装 customize-cra-less-loader 自定义 cssLoaderOptions,很简单,但没有解决我的问题,此处贴出来可以先尝试

2.3.2、方法二:弃用addLessLoader和adjustStyleLoaders,改用 addWebpackModuleRule

2.4、import styles from "index.module.less",styles是undefined,提示Cannot read properties of undefined (reading 'container')

2.5、postcss-pxtorem不生效


1、先附上各依赖版本和config-overrides.js配置代码,按这个版本和配置就没问题

"devDependencies": {"css-loader": "^6.5.1","html-webpack-plugin": "^5.0.0","less": "^4.1.2","less-loader": "^11.0.0","postcss": "^8.4.38","postcss-loader": "^8.1.1","postcss-pxtorem": "^6.0.0","style-loader": "^3.3.1","video.js": "^8.6.1","webpack": "^5.0.0"}
const {override,fixBabelImports,addWebpackAlias,addWebpackModuleRule,
} = require("customize-cra");
const path = require("path");module.exports = override((config) => ({...config,}),fixBabelImports("import", {libraryName: "antd",libraryDirectory: "es",style: "css",}),addWebpackAlias({"@": path.resolve(__dirname, "src"),}),addWebpackModuleRule({test: [/\.css$/],use: ["style-loader", "css-loader", "postcss-loader"],}),addWebpackModuleRule({test: [/\.less$/],use: ["style-loader",{loader: "css-loader",options: {// url?, import?, modules?, sourceMap?, importLoaders?, esModule?, exportType?modules: {localIdentName: "[local]--[hash:base64:5]",},},},{loader: "less-loader",options: {lessOptions: {javascriptEnabled: true,},},},"postcss-loader",],})
);

2、问题(注意:问题顺序没有先后之分哦)

2.1、TypeError: Cannot read property 'tap' of undefined

这个问题需要webpack和html-webpack-plugin的版本保持一致,此处主动安装为较新版本,问题解决。

"html-webpack-plugin": "^5.0.0" 和 "webpack": "^5.0.0"

2.2、No module factory available for dependency type: CssDependency

这个报错是css-loader版本太低,升级css-loader就可以了

2.3、ValidationError: CSS Loader Invalid Options

2.3.1、方法一:安装 customize-cra-less-loader 自定义 cssLoaderOptions,很简单,但没有解决我的问题,此处贴出来可以先尝试

链接如下GitHub - xyy94813/customize-cra-less-loader: Add less loader to any create-react-app using customize-cra

const { override } = require("customize-cra");
const addLessLoader = require("customize-cra-less-loader");module.exports = override(addLessLoader({cssLoaderOptions: {sourceMap: true,modules: {localIdentName: "[hash:base64:8]",},},lessLoaderOptions: {lessOptions: {strictMath: true,},},})
);
2.3.2、方法二:弃用addLessLoader和adjustStyleLoaders,改用 addWebpackModuleRule
const { override, addWebpackModuleRule } = require("customize-cra");module.exports = override(addWebpackModuleRule({test: [/\.css$/],use: ["style-loader", "css-loader", "postcss-loader"],}),addWebpackModuleRule({test: [/\.less$/],use: ["style-loader",{loader: "css-loader",options: {// url?, import?, modules?, sourceMap?, importLoaders?, esModule?, exportType?modules: {localIdentName: "[local]--[hash:base64:5]",},},},{loader: "less-loader",options: {lessOptions: {javascriptEnabled: true,},},},"postcss-loader",],})
);

2.4、import styles from "index.module.less",styles是undefined,提示Cannot read properties of undefined (reading 'container')

可能是style-loader/css-loader/less-loader版本不匹配的原因。这边解决办法是将style-loader和css-loader版本改成和react-scripts写的版本一样就好了,此处可以从package-lock.json查具体版本。(注意:如果你的项目没有安装style-loader和css-loader,也可以在package-lock.json找到react-scripts对应的版本,按版本安装就好了)

2.5、postcss-pxtorem不生效

我这边解决的方法是安装postcss和postcss-loader就好了,postcss.config.js配置如图

/** 关于 postcss-pxtorem 的说明:*   用来自动将 px 单位值转换为 rem 值,开发中可以直接使用 px 单位。*/
module.exports = {plugins: {"postcss-pxtorem": {rootValue: 16,propList: ["*"],},},
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/862991.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

资金常见业务

资金业务在银行运营中扮演着举足轻重的角色,不仅是重要的资金运用渠道,也是银行资金来源的重要一环。除了通过贷款获取收益外,银行还通过多元化的资金业务实现资金的增值。 资金业务按其性质可以分为多个类别,包括长短期资金业务、…

阐述Python:except的用法和作用?

💝💝💝欢迎莅临我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:「stormsha的主页」…

网络配置(IP、NETMASK、GATEWAY、DNS、DHCP) <持续更新中>

参考: 初学Linux之网络配置(IP、NETMASK、GATEWAY、DNS、DHCP)-CSDN博客【学习笔记】网关 & 路由_网关和路由-CSDN博客【学习笔记】计算机网络 IP地址与MAC地址_根据mac分配ip-CSDN博客【学习笔记】TCP 和 UDP 协议_tcp 发送 syn 应答没有syn ack-CSDN博客 一…

一次进程虚拟内存占用超过200G问题分析

在对智驾软件系统资源进行分析时,发现一个进程虚存占用过高,超过200G top查看内存占用 有一个node应用占用了200G的虚拟内存 pmap查看该进程内存情况 pmap -x -p 8496结果显示有两个异常点,刚好和虚存使用总量吻合 一个50G和一个170G的堆…

Linux: network: 丢包分析的另一个途径 tracing

丢包的另一个思路,内核里有些counter的计数,记录的不准确。这个时候怎么办?就需要使用另外一个方式:/sys/kernel/debug/tracing/event/skb/kfree_skb 的跟踪功能。这个算是对counter的一个补充,可以拿来做统计分析使用…

udp Socket组播 服务器

什么是组播 组播也可以称之为多播这也是 UDP 的特性之一。组播是主机间一对多的通讯模式,是一种允许一个或多个组播源发送同一报文到多个接收者的技术。组播源将一份报文发送到特定的组播地址,组播地址不同于单播地址,它并不属于特定某个主机…

【云原生】最新版Kubernetes集群基于Containerd部署

Kubernetes集群基于Containerd部署 文章目录 Kubernetes集群基于Containerd部署资源列表基础环境一、基础环境准备1.1、关闭Swap分区1.2、添加hosts解析1.3、桥接的IPv4流量传递给iptables的链 二、准备Containerd容器运行时2.1、安装Containerd2.2、配置Containerd2.3、启动Co…

智慧校园-医务管理系统总体概述

智慧校园医务管理系统,作为校园健康管理体系的智能化升级,深度融合信息技术与医疗服务,为师生构筑起一道全方位的健康守护网。医务管理系统以提升校园医疗服务水平、优化健康管理流程为核心目标,通过一系列创新功能,确…

MYSQL函数进阶详解:案例解析(第19天)

系列文章目录 一、MySQL的函数(重点) 二、MySQL的窗口函数(重点) 三、MySQL的视图(熟悉) 四、MySQL的事务(熟悉) 文章目录 系列文章目录前言一、MySQL的函数1. 聚合函数2. group_c…

从入口文件搭建php项目

入口文件index.php <?phprequire CallBack.php; // 处理回调请求逻辑 $bot new CallBack();// 请求方式 if (isset($_GET[method])) {$method $_GET[method];if (method_exists($bot, $method)) {return $bot->$method();} else {echo "没有该功能";die();…

Deep Learning复习笔记0

Key Concept: Embedding: learned dense, continuous, low-dimensional representations of object 【将难以表示的对象(如图片&#xff0c;文本等)用连续的低维度的方式表示】 RNN: Recurrent Neural Network -> for processing sequential data (time series data, natur…

【单片机毕业设计选题24035】-基于STM8的便携式智能药盒控制系统

系统功能: 基于STM8的便携式智能药盒控制系统设计的总体方案设计&#xff0c;目前确定的模块主要有&#xff1a; STM8、蓝牙模块、时钟芯片、时钟和复位电路、压力传感器、声光报警电路、按键模块、系统电源模块构成。 STM8&#xff1a;核心控制器&#xff0c;完成各模块的控…

“中国象棋第一人”王天一被查:到底是因作弊还是受贿?

“中国象棋第一人”王天一被查&#xff1a;到底是因作弊还是受贿&#xff1f; 近日&#xff0c;中国象棋界掀起了一场巨大的风波&#xff0c;被誉为“中国象棋第一人”的王天一被查的消息引起了广泛的关注与热议。据悉&#xff0c;王天一因涉嫌非国家工作人员受贿被有关部门依…

npm常用命令详解与实践

npm&#xff08;Node Package Manager&#xff09;是一个JavaScript编程语言的包管理器&#xff0c;它是Node.js的默认包管理工具。npm用于管理项目中的依赖关系&#xff0c;安装、更新和发布包。 以下是一些常用的npm命令及其详解和实践示例&#xff1a; 1. npm init 初始化…

分数限制下,选好专业还是选好学校?过来人跟你说

声明&#xff1a;本文都是实在话&#xff0c;面向普通人&#xff0c;不喜勿喷。 首先呢&#xff0c;尊重你的特长和兴趣&#xff0c;有特别想去的专业或者特别想去的学校当然别犹豫。 不过呢&#xff0c;大部分人没什么特长也没什么特别喜好&#xff0c;咋选呢&#xff1f; 对大…

pc端制作一个顶部固定的菜单栏

效果 hsl颜色 hsl颜色在css中比较方便 https://www.w3school.com.cn/css/css_colors_hsl.asp 色相&#xff08;hue&#xff09;是色轮上从 0 到 360 的度数。0 是红色&#xff0c;120 是绿色&#xff0c;240 是蓝色。饱和度&#xff08;saturation&#xff09;是一个百分比值…

i-Health

技术栈&#xff1a;HTMLCSSJavascriptPHP

使用TranslateAnimation实现动画效果

使用TranslateAnimation实现动画效果 大家好&#xff0c;我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编&#xff0c;也是冬天不穿秋裤&#xff0c;天冷也要风度的程序猿&#xff01;在本文中&#xff0c;我们将探讨如何使用Android中的TranslateAnimation类…

将CSV、Excel、XML文件转换为MySQL数据库

在平时的工作中&#xff0c;经常会遇到需要将文件数据导入到数据库中的情况。有些客户之前可能只使用Excel表格作为记录工具&#xff0c;但当数据量达到一定程度或者需要将数据导入到其他系统中时&#xff0c;就会很emo,因为Excel表格虽然方便&#xff0c;但在数据处理和管理方…

web安全渗透测试十大常规项(一):web渗透测试之深入JAVA反序列化

渗透测试之PHP反序列化 1. Java反序列化1.1 FastJson反序列化链知识点1.2 FastJson反序列化链分析1.3.1 FastJson 1.2.24 利用链分析1.3.2 FastJson 1.2.25-1.2.47 CC链分析1.3.2.1、开启autoTypeSupport:1.2.25-1.2.411. Java反序列化 1.1 FastJson反序列化链知识点 1、为什…