Верстка сайту з використанням Material UI

Наша компанія займається розробкою, підтримкою та обслуговуванням сайтів будь-якої складності. Від простих односторінкових сайтів до масштабних кластерних систем, побудованих на мікро сервісах. Досвід розробників підтверджено сертифікатами від вендорів.
Розробка та обслуговування будь-яких видів сайтів:
Інформаційні сайти або веб-програми
Сайти візитки, landing page, корпоративні сайти, онлайн каталоги, квіз, промо-сайти, блоги, ресурси новин, інформаційні портали, форуми, агрегатори
Сайти або веб-програми електронної комерції
Інтернет-магазини, B2B-портали, маркетплейси, онлайн-обмінники, кешбек-сайти, біржі, дропшиппінг-платформи, парсери товарів
Веб-програми для управління бізнес-процесами
CRM-системи, ERP-системи, корпоративні портали, системи управління виробництвом, парсери інформації
Сайти або веб-програми електронних послуг
Дошки оголошень, онлайн-школи, онлайн-кінотеатри, конструктори сайтів, портали надання електронних послуг, відеохостинги, тематичні портали

Це лише деякі з технічних типів сайтів, з якими ми працюємо, і кожен із них може мати свої специфічні особливості та функціональність, а також бути адаптованим під конкретні потреби та цілі клієнта.

Пропоновані послуги
Показано 1 з 1 послугУсі 2065 послуг
Верстка сайту з використанням Material UI
Проста
~2-3 робочих дні
Часті питання
Наші компетенції:
Етапи розробки
Останні роботи
  • image_website-b2b-advance_0.png
    Розробка сайту компанії B2B ADVANCE
    1262
  • image_web-applications_feedme_466_0.webp
    Розробка веб-додатків для компанії FEEDME
    1171
  • image_websites_belfingroup_462_0.webp
    Розробка веб-сайту для компанії БЕЛФІНГРУП
    874
  • image_ecommerce_furnoro_435_0.webp
    Розробка інтернет магазину для компанії FURNORO
    1094
  • image_crm_enviok_479_0.webp
    Розробка веб-додатків для компанії Enviok
    831
  • image_bitrix-bitrix-24-1c_fixper_448_0.png
    Розробка веб-сайту для компанії ФІКСПЕР
    851

Вёрстка сайту з використанням Material UI

Material UI (MUI) — React-компонентна бібліотека, що реалізує Material Design від Google. У версії v5+ бібліотека перейшла з JSS на emotion як styling engine та надає систему тем через ThemeProvider. Набір компонентів охоплює практично весь спектр UI: від кнопок до складних data grid.

Установка та базова тема

npm install @mui/material @mui/icons-material @emotion/react @emotion/styled
// src/theme/index.ts
import { createTheme, responsiveFontSizes } from '@mui/material/styles';

declare module '@mui/material/styles' {
  interface Palette {
    neutral: Palette['primary'];
  }
  interface PaletteOptions {
    neutral?: PaletteOptions['primary'];
  }
}

let theme = createTheme({
  palette: {
    primary: {
      light: '#60a5fa',
      main: '#2563eb',
      dark: '#1d4ed8',
      contrastText: '#ffffff',
    },
    secondary: {
      main: '#7c3aed',
      contrastText: '#ffffff',
    },
    neutral: {
      main: '#6b7280',
      light: '#9ca3af',
      dark: '#374151',
      contrastText: '#ffffff',
    },
    background: {
      default: '#f9fafb',
      paper: '#ffffff',
    },
    text: {
      primary: '#111827',
      secondary: '#6b7280',
      disabled: '#9ca3af',
    },
  },
  typography: {
    fontFamily: '"Inter", "Roboto", "Helvetica", "Arial", sans-serif',
    h1: { fontWeight: 700, fontSize: '3rem' },
    h2: { fontWeight: 700, fontSize: '2.25rem' },
    h3: { fontWeight: 600, fontSize: '1.5rem' },
    h4: { fontWeight: 600, fontSize: '1.25rem' },
    body1: { fontSize: '1rem', lineHeight: 1.6 },
    body2: { fontSize: '0.875rem', lineHeight: 1.57 },
  },
  shape: {
    borderRadius: 8,
  },
  components: {
    MuiButton: {
      defaultProps: {
        disableElevation: true,
      },
      styleOverrides: {
        root: {
          textTransform: 'none',
          fontWeight: 500,
          borderRadius: 8,
        },
        sizeLarge: {
          padding: '12px 28px',
          fontSize: '1rem',
        },
      },
    },
    MuiCard: {
      defaultProps: {
        elevation: 0,
      },
      styleOverrides: {
        root: {
          border: '1px solid #f3f4f6',
          borderRadius: 12,
        },
      },
    },
    MuiTextField: {
      defaultProps: {
        variant: 'outlined',
        size: 'small',
      },
    },
  },
});

theme = responsiveFontSizes(theme);

export default theme;
// src/main.tsx
import { ThemeProvider, CssBaseline } from '@mui/material';
import theme from './theme';

function App() {
  return (
    <ThemeProvider theme={theme}>
      <CssBaseline />
      <Router>...</Router>
    </ThemeProvider>
  );
}

Приклади компонентів

Hero-секція

import { Box, Container, Typography, Button, Stack } from '@mui/material';

const HeroSection = () => (
  <Box
    component="section"
    sx={{
      py: { xs: 8, md: 14 },
      background: 'linear-gradient(135deg, #eff6ff 0%, #f5f3ff 100%)',
    }}
  >
    <Container maxWidth="lg">
      <Stack
        direction={{ xs: 'column', md: 'row' }}
        spacing={6}
        alignItems="center"
      >
        <Box flex={1}>
          <Typography
            variant="h1"
            sx={{ mb: 3, fontSize: { xs: '2rem', md: '3rem' } }}
          >
            Заголовок вашого продукту
          </Typography>
          <Typography
            variant="body1"
            color="text.secondary"
            sx={{ mb: 4, fontSize: '1.125rem', maxWidth: 480 }}
          >
            Опис ціннісної пропозиції в двох-трьох реченнях.
          </Typography>
          <Stack direction="row" spacing={2} flexWrap="wrap">
            <Button variant="contained" size="large" href="/start">
              Почати безплатно
            </Button>
            <Button variant="outlined" size="large" href="/demo">
              Подивитися демо
            </Button>
          </Stack>
        </Box>
        <Box flex={1}>
          <Box
            component="img"
            src="/img/hero.webp"
            alt="Product preview"
            sx={{ width: '100%', borderRadius: 3, boxShadow: 6 }}
          />
        </Box>
      </Stack>
    </Container>
  </Box>
);

Карточки послуг

import { Grid, Card, CardContent, Typography } from '@mui/material';
import { Code, Cloud, Security } from '@mui/icons-material';

const services = [
  { icon: <Code />, title: 'Розробка', description: '...' },
  { icon: <Cloud />, title: 'Хмара', description: '...' },
  { icon: <Security />, title: 'Безпека', description: '...' },
];

const ServicesGrid = () => (
  <Grid container spacing={3}>
    {services.map((service) => (
      <Grid item xs={12} sm={6} lg={4} key={service.title}>
        <Card
          sx={{
            height: '100%',
            transition: 'box-shadow 250ms ease',
            '&:hover': { boxShadow: 4 },
          }}
        >
          <CardContent sx={{ p: 4 }}>
            <Box
              sx={{
                mb: 2,
                color: 'primary.main',
                '& svg': { fontSize: 40 },
              }}
            >
              {service.icon}
            </Box>
            <Typography variant="h4" gutterBottom>
              {service.title}
            </Typography>
            <Typography variant="body2" color="text.secondary">
              {service.description}
            </Typography>
          </CardContent>
        </Card>
      </Grid>
    ))}
  </Grid>
);

styled() для кастомних компонентів

import { styled } from '@mui/material/styles';
import { Box } from '@mui/material';

// MUI styled — доступ до теми через props
const GradientBox = styled(Box)(({ theme }) => ({
  background: `linear-gradient(135deg, ${theme.palette.primary.main}, ${theme.palette.secondary.main})`,
  borderRadius: theme.shape.borderRadius * 2,
  padding: theme.spacing(6),
  color: '#fff',

  [theme.breakpoints.down('md')]: {
    padding: theme.spacing(4),
  },
}));

Темна тема

import { createTheme } from '@mui/material/styles';
import useMediaQuery from '@mui/material/useMediaQuery';

const App = () => {
  const prefersDark = useMediaQuery('(prefers-color-scheme: dark)');

  const theme = createTheme({
    palette: {
      mode: prefersDark ? 'dark' : 'light',
      // Решта переопреділень...
    },
  });

  return <ThemeProvider theme={theme}>...</ThemeProvider>;
};

Оптимізація bundle

MUI імпортує компоненти по-компонентно автоматично через babel-plugin або через tree-shaking:

// Правильно — tree-shaking працює
import Button from '@mui/material/Button';
import Card from '@mui/material/Card';

// Або через деструктуризацію (tree-shaking в Vite теж працює)
import { Button, Card, Typography } from '@mui/material';

Іконки — тільки необхідні:

import CodeIcon from '@mui/icons-material/Code'; // Правильно
// import { Code } from '@mui/icons-material'; // Повільніше при збірці

Строки

Налаштування теми та ThemeProvider: 3–4 години (ретельна робота з дизайнером). Посадкова сторінка: 1.5–2 дні. Повний сайт з формами, модалками, таблицями даних: 4–8 днів залежно від функціонала.