Maison  >  Article  >  interface Web  >  Résumé : Cinq erreurs CSS courantes à éviter (Collection)

Résumé : Cinq erreurs CSS courantes à éviter (Collection)

青灯夜游
青灯夜游avant
2022-01-19 19:25:372614parcourir

Cet article résume les 5 erreurs CSS les plus courantes et explique comment les éviter. J'espère qu'il sera utile à tout le monde !

Résumé : Cinq erreurs CSS courantes à éviter (Collection)

Tel que nous le connaissons aujourd'hui, le langage CSS est un élément important du web. Cela nous donne la possibilité de dessiner la manière dont les éléments apparaîtront sur un écran, une page Web ou un autre média.

C'est simple, puissant et déclaratif. Nous pouvons facilement implémenter des choses complexes comme le mode sombre/clair. Cependant, il existe de nombreux malentendus et utilisations incorrectes. Ceux-ci transforment le balisage CSS en code complexe, illisible et non évolutif.

Comment pouvons-nous empêcher que cela se produise ? Évitez les erreurs les plus courantes en suivant les meilleures pratiques. Dans cet article, nous résumerons les 5 erreurs les plus courantes et comment les éviter.

1. Aucune planification préalable

Faites-le immédiatement sans réfléchir, afin de pouvoir terminer la tâche plus rapidement, ce qui nous donne également un sentiment de rapidité et d'accomplissement. Mais à long terme, cela a l’effet inverse.

Avant d'écrire du code, vous devez penser clairement. Quelle approche adopterons-nous pour concevoir les composants ? Voulons-nous construire nos composants de manière atomique ? Sommes-nous prêts à créer un système pratique et composable ? Voulons-nous une bibliothèque d’interface utilisateur déjà intégrée ? Voulons-nous que notre CSS ait une portée globale ou une portée de composant ?

Avoir un objectif clair nous aidera à choisir le meilleur outil. Cela nous évitera la redondance et les violations DRY. Il existe de nombreuses façons efficaces de concevoir une application. La chose la plus courante qui ne fonctionne pas, c'est l'improvisation.

Notre code doit être prévisible, facile à étendre et à maintenir.

Regardez un exemple :

/* ❌ 到处添加离散值 */
.card {
  color: #edb361;
  background-color: #274530;
  padding: 1rem;
}

/* ✅ 定义基于主题的属性 */
:root {
  --primary-bg-color: #274530;
  --accent-text-color: #edb361;
  --spacing-unit: 0.5;
}

.card {
  color: var(--accent-text-color);
  background-color: var(--primary-bg-color);
  padding: calc(var(--spacing-unit) * 2rem);
}

Dans l'exemple ci-dessus, nous pouvons voir que lors de l'utilisation de variables CSS pour la conception de thèmes, tout devient lisible et clair. La première définition de .card semble complètement aléatoire et ce composant n'est pas facilement extensible. .card 定义看起来完全是随机的,这个组件不容易被扩展。

2. CSS Code Smells

Code Smell中文译名一般为“代码异味”,或“代码味道”,它是提示代码中某个地方存在错误的一个暗示,开发人员可以通过这种smell(异味)在代码中追捕到问题。

Code smells 不是bug。它们也不会妨碍系统的正常工作。它们只是一些不好的做法,会使我们的代码更难阅读和维护。

在这里,列举一些最常见的以及如何克服它们:

:: 符号

在伪元素和伪类中使用 :: 符号是很常见的。这是旧的CSS规范的一部分,浏览器继续支持它作为一种回退。然而,我们应该在伪元素中使用 ::,比如 ::before, ::after, ::frist-line...,在伪类中使用:,比如:link, :visited, :first-child...

使用字符串连接类

使用Sass预处理器来帮助处理我们的CSS代码库是非常流行的。有时在尝试DRY时,我们通过连接&操作符来创建类。

.card {
  border: 0.5 solid rem #fff;
  
  /* ❌ failed attempt to be dry */
  &-selected {
    border-color: #000;
  }
}

在开发人员试图在代码库中搜索.card-selected类之前,似乎没有什么问题。开发者将很难找到这个类。

不正确地使用缩写

CSS的简写非常好,可以让我们避免代码过于冗长。但是,有时我们并没有刻意地使用它们。大多数情况下,background 简写是偶然使用的。

/* ❌ 由于我们只是在设置一个属性,所以不需要使用简写。*/
.foo {
  background: #274530;
}

/* ✅ 使用正确的CSS属性 */
.foo {
  background-color: #274530;
}

!important  的错误使用

!important 规则用于覆盖特定性规则。它的使用主要集中在覆盖一个不能以任何其他方式覆盖的样式。

它通常用于更具体的选择器可以完成任务的场景。

<div class="inner">
  <p>This text is in the inner div.</p>
</div>


<style>
  .inner {
    color: blue;
  }
  
  /* ❌ 重写 color */
  .inner {
    color: orange !important;
  }
</style>


<style>
  .inner {
    color: blue;
  }
  
  /* ✅ 使用一个更具体的选择器规则,该规则将优先于更一般的规则。 */
  .inner p {
    color: orange;
  }
</style>

强制使用属性值

在CSS代码库中出现一个神奇的数字是很常见的。它们带来了相当多的混乱。有时,我们可能会在代码中发现长的数字,因为开发者是为了覆盖一个他不确定的属性。

/* ❌ Brute 强制使这个元素位于z轴的最前面 */
.modal-confirm-dialog {
  z-index: 9999999;
}

/* ✅ 提前计划并定义所有可能的用例 */
.modal-confirm-dialog {
  z-index: var(--z-index-modal-type);
}

3.不对CSS类名进行作用域划分

由于CSS语言的特性,很容易出现元素在无意中被一个糟糕的类名定型的情况。这个问题非常频繁,所以有相当多的解决方案来解决这个问题。

在我看来,最好的两个是:

  • 使用命名约定
  • CSS Modules

命名约定

最流行的命名方式是BEM 101。它代表了 BlockElementModifier

2. CSS Code Smells

La traduction chinoise de Code Smell est généralement « odeur de code » ou « odeur de code ». C'est un indice qu'il y a une erreur quelque part dans le code. Odeur) pour localiser le problème dans le code.
Les odeurs de code ne sont pas des bugs. Ils n’empêchent pas non plus le bon fonctionnement du système. Ce ne sont que de mauvaises pratiques qui rendent notre code plus difficile à lire et à maintenir.

Voici quelques-uns des plus courants et comment les surmonter :

:: Symbole 🎜🎜🎜🎜Il est très courant d'utiliser le symbole :: dans les pseudo-éléments et pseudo-classes. Cela fait partie de l’ancienne spécification CSS et les navigateurs continuent de la prendre en charge comme solution de secours. Cependant, nous devrions utiliser :: dans les pseudo-éléments, tels que ::before, ::after, ::frist- ligne ..., utilisez : dans les pseudo-classes, telles que :link, :visited, :first -child ...🎜🎜🎜🎜Utilisation de la classe de concaténation de chaînes 🎜🎜🎜🎜Il est très courant d'utiliser les préprocesseurs Sass pour nous aider avec nos bases de code CSS. Parfois, en essayant DRY, nous créons des classes en concaténant les opérateurs &. 🎜
[block]__[element]--[modifier]
/* Example */
.menu__link--blue {
  ...
}
🎜 Il ne semblait y avoir aucun problème jusqu'à ce que le développeur essaie de rechercher dans la base de code la classe .card-selected. Les développeurs auront du mal à trouver cette classe. 🎜🎜🎜🎜Utilisation incorrecte des abréviations 🎜🎜🎜🎜 Les abréviations CSS sont géniales et nous permettent d'éviter un code trop verbeux. Cependant, parfois nous ne les utilisons pas intentionnellement. La plupart du temps, l’abréviation d’arrière-plan est utilisée accidentellement. 🎜
.article-column {
  /* ✅  我们的元素将最多容纳20个继承的字体大小的字符。 */
  max-width: 20ch;
}
🎜🎜🎜!important Une utilisation incorrecte des règles 🎜🎜🎜🎜!important est utilisée pour remplacer les règles de spécificité. Son utilisation est principalement axée sur le remplacement d'un style qui ne peut être remplacé d'aucune autre manière. 🎜🎜Il est généralement utilisé dans des scénarios où un sélecteur plus spécifique peut accomplir la tâche. 🎜rrreee🎜🎜🎜Forcer les valeurs des propriétés 🎜🎜🎜🎜 Il est très courant qu'un nombre magique apparaisse dans les bases de code CSS. Ils apportent pas mal de confusion. Parfois, nous pouvons trouver des nombres longs dans le code parce que le développeur remplace une propriété dont il n'est pas sûr. 🎜rrreee🎜3. Ne définissez pas les noms de classe CSS🎜🎜En raison des caractéristiques du langage CSS, il est facile pour des éléments d'être stéréotypés par inadvertance par un mauvais nom de classe. Ce problème est très fréquent, il existe donc de nombreuses solutions pour résoudre ce problème. 🎜🎜À mon avis, les deux meilleurs sont : 🎜
  • Utiliser les conventions de nommage
  • Modules CSS
🎜🎜🎜Conventions de nommage🎜🎜🎜🎜 Les plus populaires Le schéma de dénomination est BEM 101. Il représente les méthodes Block, Element et Modifier. 🎜rrreee🎜 Son but est de créer des noms uniques en permettant aux développeurs de comprendre la relation entre HTML et CSS. 🎜🎜🎜🎜Modules CSS🎜🎜🎜

我对BEM方法最大的担心是,它很耗时,而且要依靠开发人员来实现。CSS模块发生在预处理器一侧,这使得它没有错误。它为我们的CSS模块类名生成了随机的前缀/名称。

4. 使用 px 单位

像素的使用相当频繁,因为它起初看起来很容易和直观的使用。事实恰恰相反。很久以来,像素已经不再基于硬件了。它们只是基于一个光学参考单元。

px是一个绝对单位。这意味着什么呢?那就是我们不能适当地缩放以满足更多的人。

我们应该用什么来代替?相对单位是要走的路。我们可以依靠这些来更好地表达我们的动态布局。例如,我们可以使用ch来表达一个基于字符数的div宽度。

.article-column {
  /* ✅  我们的元素将最多容纳20个继承的字体大小的字符。 */
  max-width: 20ch;
}

通常情况下,px最常用的替换单位是remem。它们以一种从框到文本的相对方式来表示字体的相对大小。

  • rem 表示相对于根 font-size 的大小。
  • em 表示相对于元素大小的大小。

通过使用 rem,我们将能够根据用户偏好的字体大小来表达布局。

Résumé : Cinq erreurs CSS courantes à éviter (Collection)

在上面的截图中,我们可以看到基于 rem 单元的布局如何能够扩展并适应不同的默认字体大小。

5. 忽略浏览器支持

当开始开发一个网站时,定义我们的目标客户是至关重要的。跳过这一步,直接进行编码是很常见的。

为什么它至关重要?它帮助我们了解我们的应用程序将在哪种设备上使用。之后,我们可以定义我们将支持哪些浏览器和哪些版本。

只要我们能提供适当的后备方案,我们仍然可以致力于接受像subgrid这样的后期功能。定义一个渐进的功能体验总是一个好主意。当一个特性得到更多的支持时,我们可以逐步抛弃它的后备方案。

像caniuse.com或browserslist.dev这样的工具在这方面很有帮助。像postcss这样的工具自带的autoprefixer功能将帮助我们的CSS得到更广泛的支持。

总结

我们已经看到了如何改进我们的CSS代码。遵循一些简单的指导原则,我们可以实现一个声明式、可重用和可读的代码库。我们应该在CSS中投入和在Javascript中一样多的精力。

英文原文地址:https://levelup.gitconnected.com/top-5-css-mistakes-to-avoid-963f76892954

作者: Jose Granja

(学习视频分享:css视频教程

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!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer