Maison >interface Web >js tutoriel >Composants MUI : votre guide complet pour créer des interfaces utilisateur React modernes
Material-UI (MUI) est une bibliothèque d'interface utilisateur React populaire qui simplifie la création d'applications Web réactives et visuellement attrayantes. Avec un riche ensemble de composants prédéfinis comme Autocomplete, Stack, Select, Card, Accordion, Stepper, et Badge, MUI permet de gagner du temps de développement tout en garantissant la cohérence et la réactivité de la conception.
Ce guide explore comment utiliser et personnaliser efficacement ces composants, avec des exemples pratiques pour vous aider à les intégrer de manière transparente dans vos projets. Que vous soyez débutant ou développeur expérimenté, cet article améliorera votre compréhension de MUI et de ses capacités.
Avant de plonger dans les composants MUI, assurez-vous que votre environnement de développement est prêt. Ce guide suppose que vous avez une compréhension de base de React et que vous avez déjà configuré une application React. Si vous démarrez à zéro ou préférez une configuration plus rapide et légère, envisagez d'utiliser Vite, un outil de construction moderne pour les projets front-end. Pour connaître les étapes détaillées de configuration de Vite avec React, reportez-vous à notre Guide du débutant sur l'utilisation de Vite avec React.
De plus, assurez-vous d'avoir Material-UI (MUI) installé dans votre projet. Vous pouvez le faire en exécutant la commande suivante :
npm install @mui/material @emotion/react @emotion/styled
Une fois votre application React configurée, la prochaine étape consiste à intégrer MUI
Material-UI (MUI) fournit un système de thèmes puissant qui garantit la cohérence de la conception entre tous les composants de votre application. Un thème personnalisé contrôle les couleurs, la typographie, l'espacement et bien plus encore, garantissant ainsi l'alignement avec votre marque.
Voici comment configurer un thème de base dans MUI :
Importer les utilitaires requis : utilisez createTheme pour définir votre thème personnalisé et ThemeProvider pour l'appliquer globalement.
Définissez votre thème : spécifiez les valeurs de la palette, de la typographie et d'autres propriétés de conception.
Enveloppez votre application : utilisez ThemeProvider pour transmettre le thème à l'ensemble de votre application ou à des sections spécifiques.
import React from 'react'; import { createTheme, ThemeProvider } from '@mui/material/styles'; import { Button } from '@mui/material'; // Define a custom theme const theme = createTheme({ palette: { primary: { main: '#1976d2', // Primary color }, secondary: { main: '#dc004e', // Secondary color }, }, typography: { fontFamily: 'Roboto, Arial, sans-serif', }, }); function App() { return ( <ThemeProvider theme={theme}> <Button variant="contained" color="primary"> Primary Button </Button> <Button variant="outlined" color="secondary"> Secondary Button </Button> </ThemeProvider> ); } export default App;
En configurant un thème, vous rationalisez le processus de conception, maintenez la cohérence et simplifiez les futures mises à jour de l'apparence de votre application.
MUI propose une variété de composants pour rationaliser le développement de l'interface utilisateur. Ci-dessous, nous explorons certains des composants les plus couramment utilisés, leur utilisation de base et leurs options de personnalisation.
La saisie semi-automatique améliore les saisies utilisateur en fournissant des suggestions à partir d'une liste prédéfinie.
Exemple de base :
npm install @mui/material @emotion/react @emotion/styled
Personnalisation :
Stack organise les composants selon une disposition unidimensionnelle (horizontale ou verticale).
Exemple de base :
import React from 'react'; import { createTheme, ThemeProvider } from '@mui/material/styles'; import { Button } from '@mui/material'; // Define a custom theme const theme = createTheme({ palette: { primary: { main: '#1976d2', // Primary color }, secondary: { main: '#dc004e', // Secondary color }, }, typography: { fontFamily: 'Roboto, Arial, sans-serif', }, }); function App() { return ( <ThemeProvider theme={theme}> <Button variant="contained" color="primary"> Primary Button </Button> <Button variant="outlined" color="secondary"> Secondary Button </Button> </ThemeProvider> ); } export default App;
Personnalisation :
Select est un composant déroulant pour les choix des utilisateurs.
Exemple de base :
import React from 'react'; import { Autocomplete, TextField } from '@mui/material'; const options = ['Option 1', 'Option 2', 'Option 3']; function AutocompleteExample() { return ( <Autocomplete options={options} renderInput={(params) => <TextField {...params} label="Select an Option" />} /> ); } export default AutocompleteExample;
Personnalisation :
L'accordéon est idéal pour les sections pliables comme les FAQ.
Exemple de base :
import React from 'react'; import { Stack, Button } from '@mui/material'; function StackExample() { return ( <Stack direction="row" spacing={2}> <Button variant="contained">Button 1</Button> <Button variant="outlined">Button 2</Button> </Stack> ); } export default StackExample;
Personnalisation :
Stepper crée des flux de travail ou des processus en plusieurs étapes.
Exemple de base :
import React, { useState } from 'react'; import { Select, MenuItem, FormControl, InputLabel } from '@mui/material'; function SelectExample() { const [value, setValue] = useState(''); const handleChange = (event) => setValue(event.target.value); return ( <FormControl fullWidth> <InputLabel> <p><strong>Customization:</strong> </p> <ul> <li>Enable multiple selections with multiple. </li> <li>Render custom items with renderValue.</li> </ul> <p><img src="https://img.php.cn/upload/article/000/000/000/173546599689834.jpg" alt="MUI Components: Your Complete Guide to Building Modern React UIs" /></p> <h4> <strong>4. MUI Card</strong> </h4> <p>Card displays structured content like text, images, and actions.</p> <p><strong>Basic Example:</strong><br> </p> <pre class="brush:php;toolbar:false">import React from 'react'; import { Card, CardContent, Typography } from '@mui/material'; function CardExample() { return ( <Card> <CardContent> <Typography variant="h5">Card Title</Typography> <Typography variant="body2">Card Content</Typography> </CardContent> </Card> ); } export default CardExample;
Personnalisation :
![MUI Stepper(https://dev-to-uploads.s3.amazonaws.com/uploads/articles/l6oockmr57d8wgj659hy.png)
Le badge met en évidence les notifications ou les décomptes, généralement sur des icônes.
Exemple de base :
import React from 'react'; import { Accordion, AccordionSummary, AccordionDetails, Typography } from '@mui/material'; import ExpandMoreIcon from '@mui/icons-material/ExpandMore'; function AccordionExample() { return ( <Accordion> <AccordionSummary expandIcon={<ExpandMoreIcon />}> <Typography>Accordion Title</Typography> </AccordionSummary> <AccordionDetails> <Typography>Accordion Content</Typography> </AccordionDetails> </Accordion> ); } export default AccordionExample;
Personnalisation :
Ces composants clés de MUI constituent une base pour créer des interfaces intuitives et réactives. Avec des options de personnalisation et des exemples pratiques, vous pouvez facilement les adapter aux besoins de votre projet.
Pour maximiser l'efficacité et la maintenabilité de vos projets avec Material-UI (MUI), tenez compte des bonnes pratiques suivantes :
npm install @mui/material @emotion/react @emotion/styled
import React from 'react'; import { createTheme, ThemeProvider } from '@mui/material/styles'; import { Button } from '@mui/material'; // Define a custom theme const theme = createTheme({ palette: { primary: { main: '#1976d2', // Primary color }, secondary: { main: '#dc004e', // Secondary color }, }, typography: { fontFamily: 'Roboto, Arial, sans-serif', }, }); function App() { return ( <ThemeProvider theme={theme}> <Button variant="contained" color="primary"> Primary Button </Button> <Button variant="outlined" color="secondary"> Secondary Button </Button> </ThemeProvider> ); } export default App;
import React from 'react'; import { Autocomplete, TextField } from '@mui/material'; const options = ['Option 1', 'Option 2', 'Option 3']; function AutocompleteExample() { return ( <Autocomplete options={options} renderInput={(params) => <TextField {...params} label="Select an Option" />} /> ); } export default AutocompleteExample;
En suivant ces bonnes pratiques, vous pouvez créer des applications efficaces, évolutives et maintenables tout en exploitant tout le potentiel de MUI.
Les composants Material-UI (MUI) simplifient le processus de création d'applications Web réactives et modernes et d'un système de thèmes puissant. En suivant les bonnes pratiques décrites dans ce guide, vous pouvez créer des interfaces cohérentes, accessibles et hautement personnalisables qui améliorent l'expérience utilisateur. Que vous soyez débutant ou développeur expérimenté, MUI fournit les outils nécessaires pour élever efficacement vos projets React.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!