Maison > interface Web > tutoriel CSS > Des pratiques CSS révolutionnaires qui amélioreront votre code

Des pratiques CSS révolutionnaires qui amélioreront votre code

Barbara Streisand
Libérer: 2024-12-02 18:43:11
original
744 Les gens l'ont consulté

Game-Changing CSS Practices That Will Level Up Your Code

Tous les développeurs ont été là – aux prises avec des CSS qui semblaient simples au début mais sont rapidement devenus lourds. Dans ce guide, nous explorerons les pièges CSS courants et leurs solutions modernes et maintenables. Transformons votre CSS de problématique à professionnel !

? Recevez chaque semaine des conseils CSS, des extraits de code et des didacticiels directement dans votre boîte de réception - 100 % gratuitement !

1. Unités : se libérer des pixels

La mauvaise façon :

.container {
    width: 1200px;
    font-size: 16px;
    margin: 20px;
}
Copier après la connexion
Copier après la connexion

La meilleure façon :

.container {
    width: 90vw;
    max-width: 75rem;
    font-size: 1rem;
    margin: 1.25rem;
}
Copier après la connexion
Copier après la connexion

L'utilisation d'unités relatives rend votre conception réactive et accessible. Les REM s'adaptent à la taille de police préférée de l'utilisateur, tandis que les unités de fenêtre garantissent que votre mise en page s'adapte aux différentes tailles d'écran. Considérez toujours que les utilisateurs peuvent zoomer ou modifier la taille de leur police de base.

2. Réinitialisation CSS : repartir à zéro

La mauvaise façon :

/* Starting without any reset, relying on browser defaults */
Copier après la connexion
Copier après la connexion

La meilleure façon :

*, *::before, *::after {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    font-size: 16px;
    -webkit-text-size-adjust: 100%;
}
Copier après la connexion
Copier après la connexion

Une réinitialisation CSS garantit un rendu cohérent sur différents navigateurs. La propriété box-sizing: border-box rend les calculs de largeur intuitifs en incluant le remplissage et la bordure dans la largeur totale de l'élément.

3. Flexbox vs Float : solutions de mise en page modernes

La mauvaise façon :

.container {
    overflow: hidden;
}
.sidebar {
    float: left;
    width: 300px;
}
.main {
    margin-left: 320px;
}
Copier après la connexion
Copier après la connexion

La meilleure façon :

.container {
    display: flex;
    gap: 1.25rem;
}
.sidebar {
    flex-basis: 18.75rem;
    flex-shrink: 0;
}
.main {
    flex-grow: 1;
}
Copier après la connexion
Copier après la connexion

Flexbox fournit des mises en page puissantes et flexibles avec moins de code. Il gère l'espacement, l'alignement et la réactivité avec plus d'élégance que les éléments flottants, et il est mieux pris en charge dans les navigateurs modernes.

4. Gestion des couleurs : variables de cohérence

La mauvaise façon :

.button {
    background-color: #007bff;
}
.link {
    color: #007bff;
}
Copier après la connexion
Copier après la connexion

La meilleure façon :

:root {
    --primary-color: #007bff;
    --primary-hover: #0056b3;
}

.button {
    background-color: var(--primary-color);
}
.button:hover {
    background-color: var(--primary-hover);
}
.link {
    color: var(--primary-color);
}
Copier après la connexion
Copier après la connexion

Les variables CSS (propriétés personnalisées) facilitent le maintien de couleurs cohérentes et permettent le changement de thème. Ils rendent également votre code plus maintenable et réduisent le risque d'incohérences.

5. Requêtes multimédias : approche axée sur le mobile

La mauvaise façon :

/* Desktop-first approach */
.container {
    width: 1200px;
}
@media (max-width: 768px) {
    .container {
        width: 100%;
    }
}
Copier après la connexion

La meilleure façon :

/* Mobile-first approach */
.container {
    width: 100%;
}
@media (min-width: 48em) {
    .container {
        width: 90%;
        max-width: 75rem;
    }
}
Copier après la connexion

La conception axée sur le mobile garantit que vos styles de base fonctionnent pour les appareils plus petits, puis améliore progressivement l'expérience pour les écrans plus grands. Cette approche aboutit généralement à un code plus propre et plus maintenable.

6. Spécificité : faire simple

La mauvaise façon :

#header div.navigation ul li a.active {
    color: blue;
}
Copier après la connexion

La meilleure façon :

.nav-link--active {
    color: var(--primary-color);
}
Copier après la connexion

Une spécificité plus faible rend les styles plus faciles à entretenir et à remplacer en cas de besoin. Utilisez la convention de dénomination BEM ou une méthodologie similaire pour créer des classes significatives et spécifiques sans imbrication profonde.

7. Typographie : dimensionnement fluide des polices

La mauvaise façon :

.container {
    width: 1200px;
    font-size: 16px;
    margin: 20px;
}
Copier après la connexion
Copier après la connexion

La meilleure façon :

.container {
    width: 90vw;
    max-width: 75rem;
    font-size: 1rem;
    margin: 1.25rem;
}
Copier après la connexion
Copier après la connexion

L'utilisation de clamp() crée une typographie réactive qui s'adapte en douceur entre les tailles minimales et maximales. Cela élimine le besoin de plusieurs requêtes multimédias uniquement pour les tailles de police.

8. Disposition de la grille : systèmes de cartes appropriés

La mauvaise façon :

/* Starting without any reset, relying on browser defaults */
Copier après la connexion
Copier après la connexion

La meilleure façon :

*, *::before, *::after {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    font-size: 16px;
    -webkit-text-size-adjust: 100%;
}
Copier après la connexion
Copier après la connexion

La grille CSS avec ajustement automatique et minmax() crée des mises en page réactives qui s'ajustent automatiquement à l'espace disponible. Cette approche nécessite moins de code et gère mieux les cas extrêmes.

9. Animation : optimisation des performances

La mauvaise façon :

.container {
    overflow: hidden;
}
.sidebar {
    float: left;
    width: 300px;
}
.main {
    margin-left: 320px;
}
Copier après la connexion
Copier après la connexion

La meilleure façon :

.container {
    display: flex;
    gap: 1.25rem;
}
.sidebar {
    flex-basis: 18.75rem;
    flex-shrink: 0;
}
.main {
    flex-grow: 1;
}
Copier après la connexion
Copier après la connexion

Spécifiez les propriétés exactes à animer au lieu de toutes les utiliser, et utilisez la transformation et l'opacité lorsque cela est possible, car elles sont optimisées pour les performances. Utilisez will-change avec parcimonie pour les éléments fréquemment animés.

10. Propriétés personnalisées pour les variantes de composants

La mauvaise façon :

.button {
    background-color: #007bff;
}
.link {
    color: #007bff;
}
Copier après la connexion
Copier après la connexion

La meilleure façon :

:root {
    --primary-color: #007bff;
    --primary-hover: #0056b3;
}

.button {
    background-color: var(--primary-color);
}
.button:hover {
    background-color: var(--primary-hover);
}
.link {
    color: var(--primary-color);
}
Copier après la connexion
Copier après la connexion

L'utilisation des propriétés personnalisées CSS pour les variantes réduit la duplication de code et rend les composants plus maintenables. Cela facilite également la création de variations cohérentes dans votre système de conception.

Conclusion

Le CSS moderne fournit des outils puissants qui peuvent rendre votre code plus maintenable, plus performant et évolutif. En suivant ces bonnes pratiques, vous créerez des feuilles de style plus robustes, plus faciles à gérer et à modifier. N'oubliez pas que l'objectif n'est pas seulement de faire fonctionner quelque chose, mais de le faire fonctionner correctement à la fois pour les utilisateurs et les développeurs.

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!

source:dev.to
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal