使用create-react-app
建立的項目默認不支持less
,如下增長less
配置的步驟css
create-react-app
生成的項目文,看不到webpack相關的配置文件,須要先暴露出來,使用以下命令便可:html
npm run eject
less-loader
和 less
npm install less-loader less --save-dev
webpack
配置修改 webpack.config.dev.js
和 webpack.config-prod.js
配置文件react
改動1:webpack
/\.css$/
改成 /\.(css|less)$/,
, 修改後以下:git
exclude: [ /\.html$/, /\.(js|jsx)$/, /\.(css|less)$/, /\.json$/, /\.bmp$/, /\.gif$/, /\.jpe?g$/, /\.png$/, ],
改動2:github
test: /\.css$/
改成 /\.(css|less)$/
test: /\.css$/
的 use
數組配置增長 less-loader
修改後以下:web
{ test: /\.(css|less)$/, use: [ require.resolve('style-loader'), { loader: require.resolve('css-loader'), options: { importLoaders: 1, }, }, { loader: require.resolve('postcss-loader'), options: { // Necessary for external CSS imports to work // https://github.com/facebookincubator/create-react-app/issues/2677 ident: 'postcss', plugins: () => [ require('postcss-flexbugs-fixes'), autoprefixer({ browsers: [ '>1%', 'last 4 versions', 'Firefox ESR', 'not ie < 9', // React doesn't support IE8 anyway ], flexbox: 'no-2009', }), ], }, }, { loader: require.resolve('less-loader') // compiles Less to CSS } ], },