Реакция: загрузчик sass не переносит S CSS в CSS - PullRequest
2 голосов
/ 04 апреля 2020

У меня есть приложение react с CSS файлами, работающими нормально. Мне нужно начать использовать SCSS, поэтому следующие изменения:

  1. Установить node-sass и sass-loader
  2. Изменить импорт с .css на .scss
  3. Изменить расширение файла с .css на .scss

Но мои страницы загружаются неправильно:

Текущее поведение: enter image description here

Ожидается Поведение: enter image description here

Мой код:

package.json

{
  "name": "frontend",
  "version": "0.1.0",
  "private": true,
  "dependencies": {
    "@coreui/coreui": "^3.0.0",
    "@stardust-ui/docs-components": "^0.40.0",
    "axios": "^0.19.0",
    "bootstrap": "^4.4.1",
    "compass": "^0.1.1",
    "css-loader": "^3.4.2",
    "mdbreact": "^4.25.4",
    "prettier": "^1.6.1",
    "prop-types": "^15.7.2",
    "react": "^16.10.2",
    "react-bootstrap": "^1.0.0-beta.16",
    "react-bootstrap-sidebar": "0.0.1",
    "react-dom": "^16.10.2",
    "react-fixed-bottom": "^1.0.2",
    "react-modal": "^3.11.1",
    "react-rangeslider": "^2.2.0",
    "react-router-dom": "^5.1.2",
    "react-scripts": "^1.1.5",
    "reconnecting-websocket": "^4.2.0",
    "reconnectingwebsocket": "^1.0.0",
    "semantic-ui-react": "^0.88.2",
    "style-loader": "^1.1.3",
    "styled-components": "^4.4.1"
  },
  "scripts": {
    "start": "PORT=3000 react-scripts start",
    "build": "react-scripts build",
    "test": "react-scripts test --env=jsdom",
    "eject": "react-scripts eject"
  },
  "devDependencies": {
    "node-sass": "^4.13.1",
    "sass-loader": "^8.0.2"
  }
}

Я ввел код для загрузчиков в node_modules / Reaction-scripts / config / webpack. config.dev. js вот так:

// Process JS with Babel.
          {
            test: /\.(js|jsx|mjs)$/,
            include: paths.appSrc,
            loader: require.resolve('babel-loader'),
            options: {
              // @remove-on-eject-begin
              babelrc: false,
              presets: [require.resolve('babel-preset-react-app')],
              // @remove-on-eject-end
              // This is a feature of `babel-loader` for webpack (not Babel itself).
              // It enables caching results in ./node_modules/.cache/babel-loader/
              // directory for faster rebuilds.
              cacheDirectory: true,
            },
          },
          { 
            test: /\.scss$/, 
            loader: [
              "css-loader",
              "sass-loader"
            ]
          },

Вот мой компонент:

import React, { Component } from "react";
import '../../../general.scss';
import { Warning } from '../../../images/images_svg';

class Terminos extends Component{
  state = { error: false }

  saveAndContinue = () => {
    if(this.props.values.terminos) {
       this.props.nextStep()      
    }
    else {
       console.log(this.props.values.terminos_error)
       this.props.mandar_error('terminos_error')
    }     
  }

  render() { 
    return (
      <div className="formulario">
        <div className="formulario-seccion-titulo">
          <div className="formulario-seccion-barrita"/>
            <div className="formulario-seccion-content">
               Presentacion
            </div>
          </div>      
          <div className={this.props.values.terminos_error ? "formulario-seccion" : "formulario-seccion-red"}>
             La actual pandemia que afecta al mundo trae consecuencias a nivel sanitario, económico y social. Lo que está ocurriendo con el COVID impacta de lleno, no sólo en la salud física de las personas, sino que también afecta de forma clara y contundente su salud mental.<br/><br/>
             Ud. puede decidir si contestar o no la encuesta que sigue pero de hacerlo,acepta que los resultados de la misma sean compartidos con su empleador con el único fin de brindarle contención y asistencia. La encuesta debe completarse en las próximas 10 horas.<br/><br/>
             <input type="checkbox" 
               id="terminos" 
               className="formulario-checkbox"
               onChange={() => this.props.handleTerminos()}
               checked={this.props.values.terminos}
             />  
             <label className="formulario-checkbox-label" htmlFor="terminos"> 
               Acepto terminos y condiciones.
             </label>
             {this.props.values.terminos_error===false &&
                <div className="formulario-seccion-error">
                  <div className="formulario-seccion-error-logo" >
                    <Warning color="#d93025"/>
                  </div>
                    Debes aceptar los terminos y condiciones para continuar
                </div>
              }
           </div>
           <div className="formulario-footer">
             <button className="formulario-botones" onClick={this.saveAndContinue}>Siguiente</button>
           </div>
         </div>
       )    
    }
}

export default Terminos;

Если я изменю импорт и расширение файла с .scss на .css страница загружается правильно. Я использую npm start для разработки и тестирования кода.

Ответы [ 3 ]

0 голосов
/ 05 апреля 2020

Webpack претерпел огромные изменения вплоть до version 4

Когда мы используем create-react-app, он устанавливает совместимую версию Webpack, которую react-scripts использует для комплектации ваши файлы и служат им, используя Webpack-server в качестве сервера разработки, когда вы запускаете npm start.

  • Удалите "webpack": "^3.11.0" из вашего package.json, поскольку он уже установлен react-scripts.

  • Также react 16+ часто работает с react-scripts 3+, поэтому, если вы вручную отредактировали часть этого package.json файла, я рекомендую оставить значения по умолчанию, установленные create-react-app, и просто добавить свои прочее dependencies.

В противном случае вот Что говорит Webpack о загрузчиках .

0 голосов
/ 08 апреля 2020

Хорошо, я решил это, удалив папку node-modules, package-lock. json и все мои зависимости в пакете. json. Затем я переустановил все свои зависимости с npm install .... Я думаю, что проблема заключалась в модуле реагирующих сценариев, я обновил с версии 1.1.5 до 3.4.1. Спасибо всем за ответы.

0 голосов
/ 04 апреля 2020

Вы создали проект с помощью Create-React-App? В этом случае вам не нужен sass-loader , вам просто нужно node-sass и импортируйте ваш стиль CSS в ваш файл root с помощью .scss / sass расширение, например, import '../example.scss', затем необходимо настроить webpack.config. js.

Пожалуйста, предоставьте дополнительную информацию.

Хорошего дня.

...