react接入less

文章介绍了如何在React项目中安装并配置less-loader以处理less文件,包括exposewebpack配置、修改webpack.config.js、添加less规则以及处理模块化。通过这些步骤,开发者可以顺利地在项目中引入并使用less预处理器。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

安装less

npm i  less less-loader@5.0.0

注:新版的less-loader不兼容

暴露webpack配置

react的webpack配置是默认隐藏的,封装在react脚手架包里。
要想加入自己的配置,需要暴露出webpack文件。

npm run eject

注:对应
“eject”: “react-scripts eject”
会显示出默认的配置文件:

里面有个webpack.config.js文件,就是我们要写自己的配置的地方。

添加配置

添加正则

const cssRegex = /\.css$/;
const cssModuleRegex = /\.module\.css$/;

下面添加

const lessRegex = /\.less$/;
const lessModuleRegex = /\.module\.less$/;

修改loaders方法

const getStyleLoaders = (cssOptions, preProcessor) => {

改为

const getStyleLoaders = (cssOptions, lessOptions, preProcessor) => {

添加less-loader

{
        loader: require.resolve('css-loader'),
        options: cssOptions,
      },

下面添加

      {
        loader: require.resolve('less-loader'),
        options: lessOptions,
      },

添加规则

            {
              test: sassModuleRegex,
              use: getStyleLoaders(
                {
                  importLoaders: 3,
                  sourceMap: isEnvProduction
                    ? shouldUseSourceMap
                    : isEnvDevelopment,
                  modules: {
                    mode: 'local',
                    getLocalIdent: getCSSModuleLocalIdent,
                  },
                },
                'sass-loader'
              ),
            },

后面添加

            /** less */
            {
              test: lessRegex,
              exclude: lessModuleRegex,
              use: getStyleLoaders(
                {
                  importLoaders: 3,
                  sourceMap: isEnvProduction
                    ? shouldUseSourceMap
                    : isEnvDevelopment,
                  modules: {
                    mode: 'icss',
                  },
                },
                'less-loader'
              ),
              sideEffects: true,
            },
            {
              test: lessModuleRegex,
              use: getStyleLoaders(
                {
                  importLoaders: 3,
                  sourceMap: isEnvProduction
                    ? shouldUseSourceMap
                    : isEnvDevelopment,
                  modules: {
                    mode: 'local',
                    getLocalIdent: getCSSModuleLocalIdent,
                  },
                },
                'less-loader'
              ),
            },

重启npm run start即可

示例

index.less

@def: pink;

.color1 {
    color: @def;
}

index.js

import './index.less';
//使用样式
<h3 className="color1">hello react!</h3>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

草宝虫

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值