在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
這篇文章主要為大家詳細(xì)介紹了如何在React中優(yōu)雅的使用addEventListener,文中的示例代碼簡(jiǎn)潔易懂,對(duì)大家學(xué)習(xí)React有一定的幫助,需要的可以參考一下2023-01-01React使用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,使用 Hooks 能為開發(fā)提升不少效率,但并不代表就要拋棄 Class Component,依舊還有很多場(chǎng)景我們還得用到它,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-10-10從零開始最小實(shí)現(xiàn)react服務(wù)器渲染詳解
這篇文章主要介紹了從零開始最小實(shí)現(xiàn)react服務(wù)器渲染詳解,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-01-01ForwardRef?useImperativeHandle方法demo
這篇文章主要為大家介紹了ForwardRef?useImperativeHandle方法demo,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-03-03react項(xiàng)目如何使用iconfont的方法步驟
這篇文章主要介紹了react項(xiàng)目如何使用iconfont的方法步驟,這里介紹下如何在項(xiàng)目中配置。小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-03-03react中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