欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

在react配置使用less的完美方案

 更新時(shí)間:2024年04月24日 10:41:47   作者:佛系努力中……  
由于 create-react-app 使用 webpack 作為其模塊打包器,你需要修改 webpack 的配置來支持 .less 文件,這篇文章主要介紹了在react配置使用less的完美方案,需要的朋友可以參考下

在react配置使用less的最優(yōu)解

react默認(rèn)支持用scss,不支持less,直接使用less時(shí)會(huì)報(bào)錯(cuò),因此當(dāng)使用less的時(shí)候需要進(jìn)行額外配置。至于技術(shù)選型選擇less或scss完全取決于你的個(gè)人偏好。你當(dāng)然可以采取別的方式去實(shí)現(xiàn)對(duì)less的配置。但是我這里只提供了一種方式用于解決問題,主要是為了記錄,便于自己日后查看。

安裝

npm install less less-loader --save-dev
//
yarn add less less-loader --dev

配置 webpack

由于 create-react-app 使用 webpack 作為其模塊打包器,你需要修改 webpack 的配置來支持 .less 文件。為此,你可以使用 react-app-rewired 和 customize-cra。

首先,安裝這三個(gè)依賴:

npm install npm install react-app-rewired customize-cra babel-plugin-import --save-dev
//
yarn add npm install react-app-rewired customize-cra babel-plugin-import

修改你的項(xiàng)目中的 package.json 文件,將 scripts 中的 start 和 build 命令替換為使用 react-app-rewired 的命令。例如:

"scripts": {
  "start": "react-app-rewired start",
  "build": "react-app-rewired build",
  "test": "react-app-rewired test",
  "eject": "react-scripts eject"
}

-在根目錄下創(chuàng)建一個(gè)新的配置文件 config-overrides.js 在項(xiàng)目根目錄下,并添加以下內(nèi)容來覆蓋默認(rèn)的 webpack 配置以支持 Less:

config-overrides.js是一個(gè)用于覆蓋create-react-app默認(rèn)配置的文件。它允許開發(fā)人員在不強(qiáng)制eject的情況下修改webpack配置。通過使用config-overrides.js,開發(fā)人員可以添加自定義webpack配置,例如添加新的loader或plugin。

const { override, fixBabelImports, addLessLoader } = require('customize-cra');
module.exports = override(
  fixBabelImports('import', {
    libraryName: 'antd', // 如果你的項(xiàng)目中使用了 antd 或其他庫(kù)需要按需加載樣式,請(qǐng)相應(yīng)地修改這里。
    libraryDirectory: 'es', // 默認(rèn)值是 'lib',如果你使用的是 antd 的 es 模塊版本,請(qǐng)修改這里。
  }),
  addLessLoader({ lessOptions: { javascriptEnabled: true } }) // 啟用 JavaScript 在 Less 中的支持(如果需要的話)。
);

在組件中使用 Less:

現(xiàn)在你可以在組件中使用 .less 文件了。例如,你可以創(chuàng)建一個(gè)名為 MyComponent.less 的文件,并在你的 React 組件中這樣導(dǎo)入它:

import './MyComponent.less'; // 使用相對(duì)路徑導(dǎo)入你的 .less 文件。

報(bào)錯(cuò)

在配置過程中可能會(huì)出現(xiàn)以下報(bào)錯(cuò)信息

Syntax Error: ValidationError: Invalid options object. PostCSS Loader has been initialized using an options object that does not match the API schema.

options has an unknown property ‘plugins’. These properties are valid:
object { postcssOptions?, execute?, sourceMap?, implementation? }

別問,問就是我也不知道到為啥,嘗試以下方式解決

降低less-loader版本至5.0.0

yarn remove less-loader
yarn add less-loader@5.0.0

2.修改config-overrides.js配置(我是這么解決的)

customize-cra-less-loader
const { override } = require("customize-cra");
const addLessLoader = require("customize-cra-less-loader");
module.exports = override(
  addLessLoader({
    lessLoaderOptions: {
      lessOptions: {
        javascriptEnabled: true,
        modifyVars: {
          '@primary-color': '#038fde',
        }
      }
    }
  })
);

到此這篇關(guān)于在react配置使用less的最優(yōu)解的文章就介紹到這了,更多相關(guān)react配置使用less內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解如何在React中優(yōu)雅的使用addEventListener

    詳解如何在React中優(yōu)雅的使用addEventListener

    這篇文章主要為大家詳細(xì)介紹了如何在React中優(yōu)雅的使用addEventListener,文中的示例代碼簡(jiǎn)潔易懂,對(duì)大家學(xué)習(xí)React有一定的幫助,需要的可以參考一下
    2023-01-01
  • React使用xlsx和js-export-excel實(shí)現(xiàn)前端導(dǎo)出

    React使用xlsx和js-export-excel實(shí)現(xiàn)前端導(dǎo)出

    這篇文章主要為大家詳細(xì)介紹了React如何分別使用xlsx和js-export-excel實(shí)現(xiàn)前端導(dǎo)出功能,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解下
    2024-02-02
  • 在?React?項(xiàng)目中全量使用?Hooks的方法

    在?React?項(xiàng)目中全量使用?Hooks的方法

    這篇文章主要介紹了在?React?項(xiàng)目中全量使用?Hooks,使用 Hooks 能為開發(fā)提升不少效率,但并不代表就要拋棄 Class Component,依舊還有很多場(chǎng)景我們還得用到它,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2022-10-10
  • 從零開始最小實(shí)現(xiàn)react服務(wù)器渲染詳解

    從零開始最小實(shí)現(xiàn)react服務(wù)器渲染詳解

    這篇文章主要介紹了從零開始最小實(shí)現(xiàn)react服務(wù)器渲染詳解,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-01-01
  • 重新理解?React?useRef原理

    重新理解?React?useRef原理

    這篇文章主要為大家介紹了React?useRef原理的深入理解分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-05-05
  • React快速入門教程

    React快速入門教程

    本文主要介紹了React的相關(guān)知識(shí),具有一定的參考價(jià)值,下面跟著小編一起來看下吧
    2017-01-01
  • ForwardRef?useImperativeHandle方法demo

    ForwardRef?useImperativeHandle方法demo

    這篇文章主要為大家介紹了ForwardRef?useImperativeHandle方法demo,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-03-03
  • react項(xiàng)目如何使用iconfont的方法步驟

    react項(xiàng)目如何使用iconfont的方法步驟

    這篇文章主要介紹了react項(xiàng)目如何使用iconfont的方法步驟,這里介紹下如何在項(xiàng)目中配置。小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2019-03-03
  • React父子組件互相通信的實(shí)現(xiàn)示例

    React父子組件互相通信的實(shí)現(xiàn)示例

    React中是單向數(shù)據(jù)流,數(shù)據(jù)只能從父組件通過屬性的方式傳給其子組件,本文主要介紹了React父子組件互相通信的實(shí)現(xiàn)示例,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-11-11
  • react中axios結(jié)合后端實(shí)現(xiàn)GET和POST請(qǐng)求方式

    react中axios結(jié)合后端實(shí)現(xiàn)GET和POST請(qǐng)求方式

    這篇文章主要介紹了react中axios結(jié)合后端實(shí)現(xiàn)GET和POST請(qǐng)求方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-02-02

最新評(píng)論