DEV Community

Cover image for Styling in React
Suhas Palani
Suhas Palani

Posted on

Styling in React

Introduction

Styling is a crucial aspect of web development that ensures your applications are visually appealing and user-friendly. React offers several approaches to styling components, from traditional CSS and Sass to modern CSS-in-JS solutions like Styled-Components. This week, we'll dive into these methods and learn how to apply them effectively in your React projects.

Importance of Styling in React

Proper styling enhances the user experience, improves usability, and makes your application more engaging. Understanding different styling techniques allows you to choose the best approach for your specific project needs.

Traditional CSS

Using CSS with React:

  • Basic Example:
  import React from 'react';
  import './App.css';

  function App() {
      return (
          <div className="container">
              <h1 className="title">Hello, World!</h1>
          </div>
      );
  }

  export default App;
Enter fullscreen mode Exit fullscreen mode
  • App.css:
  .container {
      text-align: center;
      padding: 20px;
  }

  .title {
      color: blue;
      font-size: 2em;
  }
Enter fullscreen mode Exit fullscreen mode

CSS Modules:

  • Example:
  import React from 'react';
  import styles from './App.module.css';

  function App() {
      return (
          <div className={styles.container}>
              <h1 className={styles.title}>Hello, World!</h1>
          </div>
      );
  }

  export default App;
Enter fullscreen mode Exit fullscreen mode
  • App.module.css:
  .container {
      text-align: center;
      padding: 20px;
  }

  .title {
      color: blue;
      font-size: 2em;
  }
Enter fullscreen mode Exit fullscreen mode

Using Sass

Installing Sass:

  • Command to Install:
  npm install node-sass
Enter fullscreen mode Exit fullscreen mode

Using Sass in React:

  • App.scss:
  $primary-color: blue;
  $padding: 20px;

  .container {
      text-align: center;
      padding: $padding;
  }

  .title {
      color: $primary-color;
      font-size: 2em;
  }
Enter fullscreen mode Exit fullscreen mode
  • App Component:
  import React from 'react';
  import './App.scss';

  function App() {
      return (
          <div className="container">
              <h1 className="title">Hello, World!</h1>
          </div>
      );
  }

  export default App;
Enter fullscreen mode Exit fullscreen mode

Nested Styling with Sass:

  • Example:
  .container {
      text-align: center;
      padding: 20px;

      .title {
          color: blue;
          font-size: 2em;

          &:hover {
              color: darkblue;
          }
      }
  }
Enter fullscreen mode Exit fullscreen mode

Styled-Components

Introduction to Styled-Components:

  • Definition: A library for styling React components using tagged template literals.
  • Installation:
  npm install styled-components
Enter fullscreen mode Exit fullscreen mode

Using Styled-Components:

  • Example:
  import React from 'react';
  import styled from 'styled-components';

  const Container = styled.div`
      text-align: center;
      padding: 20px;
  `;

  const Title = styled.h1`
      color: blue;
      font-size: 2em;

      &:hover {
          color: darkblue;
      }
  `;

  function App() {
      return (
          <Container>
              <Title>Hello, World!</Title>
          </Container>
      );
  }

  export default App;
Enter fullscreen mode Exit fullscreen mode

Theming with Styled-Components:

  • Creating a Theme:
  import { ThemeProvider } from 'styled-components';

  const theme = {
      colors: {
          primary: 'blue',
          secondary: 'darkblue'
      },
      spacing: {
          padding: '20px'
      }
  };

  function App() {
      return (
          <ThemeProvider theme={theme}>
              <Container>
                  <Title>Hello, World!</Title>
              </Container>
          </ThemeProvider>
      );
  }
Enter fullscreen mode Exit fullscreen mode
  • Using Theme Values:
  import styled from 'styled-components';

  const Container = styled.div`
      text-align: center;
      padding: ${(props) => props.theme.spacing.padding};
  `;

  const Title = styled.h1`
      color: ${(props) => props.theme.colors.primary};
      font-size: 2em;

      &:hover {
          color: ${(props) => props.theme.colors.secondary};
      }
  `;
Enter fullscreen mode Exit fullscreen mode

Conclusion

Choosing the right styling approach in React depends on your project requirements and personal preference. Traditional CSS and Sass offer familiarity and simplicity, while Styled-Components provide dynamic and scoped styling capabilities. Mastering these techniques will help you build beautiful and maintainable user interfaces.

Resources for Further Learning

  • Online Courses: Websites like Udemy, Pluralsight, and freeCodeCamp offer courses on React styling techniques.
  • Books: "React and React Native" by Adam Boduch and "React Quickly" by Azat Mardan.
  • Documentation and References:
  • Communities: Join developer communities on platforms like Stack Overflow, Reddit, and GitHub for support and networking.

Top comments (0)