Ant Design с sass в React с приложением create-react-app

Я пытаюсь использовать дизайн Ant с sass в моем проекте React с помощью antd-scss-theme-plugin, но все, что я могу найти в Интернете, - это конфигурация с использованием Webpack. Мой проект был создан с помощью приложения create-react-app, и мне не нужно беспокоиться о конфигурации веб-пакета. Фактически, у меня нет файла конфигурации webpack, которым я управлял бы сам.

Я установил antd и node-sass-chokidar с npm и следил за настройками. Все работает. Я могу импортировать компоненты муравьев и использовать их, а также могу использовать sass. С помощью сценария watch-css мой CSS автоматически компилируется, и я могу видеть изменения в реальном времени.

Теперь я хотел бы переопределить меньше компонентов дизайна ant с помощью моих файлов sass, но, как я уже сказал, единственная помощь, которую я могу найти в Интернете, и единственный пакет, о котором я знаю, - это проект webpack.

Кто-нибудь использовал antd-scss-theme-plugin с приложением create-react-app или знает, как работать с конфигурацией?

Вот некоторые из моих файлов конфигурации:

.babelrc:

{
  "presets": ["env"],
  "plugins": ["transform-class-properties", "transform-object-rest-spread"]
}

config-overrides.js:

const { injectBabelPlugin } = require('react-app-rewired')

module.exports = function override(config) {
  injectBabelPlugin(
    ['import', { libraryName: 'antd', libraryDirectory: 'es', style: true }],
    config,
  )
  return config
}

package.json:

    {
  "name": "xxx",
  "version": "0.1.0",
  "private": true,
  "dependencies": {
    "antd": "^3.8.0",
    "antd-scss-theme-plugin": "^1.0.7",
    "connected-react-router": "^4.3.0",
    "history": "^4.7.2",
    "material-icons-react": "^1.0.2",
    "node-sass-chokidar": "^1.3.3",
    "npm-run-all": "^4.1.3",
    "prop-types": "^15.6.2",
    "react": "^16.4.2",
    "react-app-rewired": "^1.5.2",
    "react-dom": "^16.4.2",
    "react-redux": "^5.0.7",
    "react-router": "^4.3.1",
    "react-router-dom": "^4.3.1",
    "react-router-prop-types": "^1.0.4",
    "react-scripts": "1.1.4",
    "recompose": "^0.27.1",
    "redux": "^4.0.0",
    "redux-thunk": "^2.3.0"
  },
  "devDependencies": {
    "babel-cli": "^6.26.0",
    "babel-plugin-import": "^1.8.0",
    "babel-plugin-transform-class-properties": "^6.24.1",
    "babel-plugin-transform-object-rest-spread": "^6.26.0",
    "babel-preset-env": "^1.7.0",
    "eslint": "^4.19.1",
    "eslint-config-airbnb": "^17.0.0",
    "eslint-config-prettier": "^2.9.0",
    "eslint-plugin-import": "^2.13.0",
    "eslint-plugin-jsx-a11y": "^6.1.1",
    "eslint-plugin-react": "^7.10.0",
    "eslint-plugin-react-redux": "^2.3.0",
    "prettier": "^1.14.0"
  },
  "scripts": {
    "build-css": "node-sass-chokidar src/ -o src/",
    "watch-css": "npm run build-css && node-sass-chokidar src/ -o src/ --watch --recursive",
    "start-js": "react-app-rewired start",
    "start": "npm-run-all -p watch-css start-js",
    "build-js": "react-app-rewired build",
    "build": "npm-run-all build-css build-js",
    "test": "react-app-rewired test --env=jsdom",
    "eject": "react-scripts eject",
    "format": "prettier --write \"src/**/*.js\"",
    "lint": "eslint ."
  }
}

Спасибо за все ваши будущие ответы;)!


person Jérémy S.    schedule 09.08.2018    source источник
comment
Я думаю, вам придется катапультироваться из create-react-app. Вы нашли решение?   -  person seb    schedule 29.10.2018


Ответы (2)


У меня есть мой старый проект, работающий с SASS, CRA и Antd, используя приведенную ниже настройку конфигурации. Но если вы перейдете на официальный веб-сайт Antd, у них теперь есть обновленное руководство для настройки Antd с помощью приложения Create React. Но в любом случае они объяснили его использование с меньшим количеством, а не sass, поэтому, чтобы использовать sass в своем проекте, вы должны объединить оба CRA настройка sass и Настройка темы Antd, чтобы все работало.

Вот пример из моего проекта, в котором я использовал плагин less для обновления / настройки темы Antd. Вы должны создать файл custom-override.js в корневом каталоге вашего проекта и добавить эти строки кода.

const { override, fixBabelImports, addLessLoader } = require('customize-cra');
// you can also use craco instead of customize-cra, 
// which is now the most updated way in their current docs.

module.exports = override(
  fixBabelImports('import', {
    libraryName: 'antd',
    libraryDirectory: 'es',
    style: true,
  }),

  addLessLoader({
    javascriptEnabled: true,
    modifyVars: {
      '@primary-color': '#6237a0',
      '@link-color': '#6237a0',
      '@success-color': '#0ea70e',
      '@steps-nav-arrow-color': '#d1cdd6',
    },
  }),
);

Тогда вам просто нужно работать с scss обычным способом, как в проекте CRA на основе sass.

Чтобы использовать Sass, сначала установите node-sass:

npm install node-sass --save
# or
yarn add node-sass

Затем просто обновите свой код и переименуйте App.css в App.scss и импортируйте то же самое в основной файл (app.js). Вы даже можете расширить код, выполнив импорт / определение переменных sass и т. Д. (Все, что вы можете делать с помощью sass).

Вот снимок моего app.scss, где все мои стили определены в папке стилей.

/*
Variable definition 
*/
@import 'styles/variable';



/*
common style import 
*/
@import 'styles/common';



/**
*
# # # # # # # # # # # # # # # # # # # # # # # # # # # #
# # # # #       Components styles import    # # # # # #
# # # # # # # # # # # # # # # # # # # # # # # # # # # #
*
* below I do imports for all my routes and components.
*/

@import 'styles/dashboard';
@import 'styles/details';
person shahwarcoder    schedule 02.06.2020
comment
Вы можете мне объяснить, что у вас не сработало? Есть ли у вас конкретная проблема? Не могли бы вы поделиться кодом, чтобы я мог увидеть, что не так? - person shahwarcoder; 15.10.2020

У меня была такая же проблема, и, в конце концов, мне удалось решить ее следующим образом:

  1. Устанавливать меньше глобально

npm install -g less

  1. Создайте файл main.less и включите в него antd.less

  2. Повторно объявите переменные по умолчанию, которые вы хотите переопределить

main.less:

// main.less 
@import 'node_modules/antd/dist/antd.less 
@primary-color: #CA6027; // primary color for all components
@link-color: #5C987A; // link color
  1. Скомпилируйте main.less в css и включите этот файл в CSS:

если ваш main.less находится в src / styles, то:

lessc "./src/styles/main.less ./src/styles/css/antd.css" --js

css вывод будет:

./src/styles/css/antd.css

Теперь просто включите этот сгенерированный файл antd.css в свой app.js. И новые стили, которые вы переопределите, будут применены :) То же самое и с scss.

person jizanthapus    schedule 16.10.2020