npm install antd-mobile --save
/* src/App.js */ import {Button} from 'antd-mobile'; import 'antd-mobile/lib/button/style/css' 須要手動引入樣式 class App extends Component { render() { return ( <div className="App"> <Button type='primary'>primary</Button> </div> ); } }
npm install react-app-rewired --save-dev
/* package.json */ "scripts": { - "start": "react-scripts start", + "start": "react-app-rewired start", - "build": "react-scripts build", + "build": "react-app-rewired build", - "test": "react-scripts test", + "test": "react-app-rewired test", }
因爲使用creact-react-app建立的項目因此修改默認配置沒那麼方便,須要經過此文件修改默認配置css
module.exports = function override(config, env) { // do stuff with the webpack config... console.log(config); return config; };
運行npm run start打印出來的config,能夠看出這是webpack的開發環境配置html
mode: 'development', devtool: 'cheap-module-source-map', entry: [ '/Users/surui/Desktop/my-react-app/node_modules/react-dev-utils/webpackHotDevClient.js', '/Users/surui/Desktop/my-react-app/src/index.js' ], output: { pathinfo: true, filename: 'static/js/bundle.js', chunkFilename: 'static/js/[name].chunk.js', publicPath: '/', devtoolModuleFilenameTemplate: [Function: devtoolModuleFilenameTemplate] }, optimization: { splitChunks: { chunks: 'all', name: false }, runtimeChunk: true }, resolve: { modules: [ 'node_modules' ], extensions: [ '.mjs', '.web.js', '.js', '.json', '.web.jsx', '.jsx' ], alias: { 'react-native': 'react-native-web' }, plugins: [ [Object], [Object] ] }, resolveLoader: { plugins: [ [Object] ] }, module: { strictExportPresence: true, rules: [ [Object], [Object], [Object] ] }, plugins: [ HtmlWebpackPlugin { options: [Object], childCompilerHash: undefined, childCompilationOutputName: undefined, assetJson: undefined, hash: undefined, version: 4 }, InterpolateHtmlPlugin { htmlWebpackPlugin: [Object], replacements: [Object] }, ModuleNotFoundPlugin { appPath: '/Users/surui/Desktop/my-react-app', yarnLockFile: undefined, useYarnCommand: [Function: bound useYarnCommand], getRelativePath: [Function: bound getRelativePath], prettierError: [Function: bound prettierError] }, DefinePlugin { definitions: [Object] }, HotModuleReplacementPlugin { options: {}, multiStep: undefined, fullBuildTimeout: 200, requestTimeout: 10000 }, CaseSensitivePathsPlugin { options: {}, pathCache: {}, fsOperations: 0, primed: false }, WatchMissingNodeModulesPlugin { nodeModulesPath: '/Users/surui/Desktop/my-react-app/node_modules' }, IgnorePlugin { options: [Object], checkIgnore: [Function: bound checkIgnore] }, ManifestPlugin { opts: [Object] } ],
npm install babel-plugin-import --save-dev
const { injectBabelPlugin } = require('react-app-rewired'); module.exports = function override(config, env) { // do stuff with the webpack config... config = injectBabelPlugin(['import', { libraryName: 'antd-mobile', style: 'css', // style: true, // use less for customized theme }], config); return config; };
若是樣式用css那麼style:'css,若是用less那麼style: truenode
/* src/App.js */ import {Button} from 'antd-mobile'; class App extends Component { render() { return ( <div className="App"> <Button type='primary'>primary</Button> </div> ); } }
antd-mobile 的樣式使用了 Less 做爲開發語言react
npm install --save-dev less less-loader
"theme": { "brand-primary": "red", "color-text-base": "#333" },
const { injectBabelPlugin, getLoader } = require('react-app-rewired'); const autoprefixer = require('autoprefixer'); const theme = require('./package.json').theme; const fileLoaderMatcher = function (rule) { return rule.loader && rule.loader.indexOf(`file-loader`) != -1; } module.exports = function override(config, env) { // do stuff with the webpack config... config = injectBabelPlugin(['import', { libraryName: 'antd-mobile', // style: 'css', style: true, // use less for customized theme }], config); console.log(config.module.rules[2].oneOf); config.module.rules[2].oneOf.unshift( { test: /\.less$/, use: [ require.resolve('style-loader'), require.resolve('css-loader'), { 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'), options: { // theme vars, also can use theme.js instead of this. modifyVars: theme, }, }, ] } ); // file-loader exclude let l = getLoader(config.module.rules, fileLoaderMatcher); l.exclude.push(/\.less$/); return config; };
npm install --save-dev sass-loader
const { injectBabelPlugin, getLoader } = require('react-app-rewired'); const autoprefixer = require('autoprefixer'); const theme = require('./package.json').theme; const fileLoaderMatcher = function (rule) { return rule.loader && rule.loader.indexOf(`file-loader`) != -1; } module.exports = function override(config, env) { // do stuff with the webpack config... config = injectBabelPlugin(['import', { libraryName: 'antd-mobile', // style: 'css', style: true, // use less for customized theme }], config); console.log(config.module.rules[2].oneOf); // sass config.module.rules[2].oneOf.unshift( { test: /\.scss$/, use: [ require.resolve('style-loader'), require.resolve('css-loader'), require.resolve('sass-loader'), { 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', }) ], }, } ] } ); //less config.module.rules[2].oneOf.unshift( { test: /\.less$/, use: [ require.resolve('style-loader'), require.resolve('css-loader'), { 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'), options: { // theme vars, also can use theme.js instead of this. modifyVars: theme, }, }, ] } ); // file-loader exclude let l = getLoader(config.module.rules, fileLoaderMatcher); l.exclude.push(/\.scss$/); l.exclude.push(/\.less$/); return config; };