Maison  >  Article  >  interface Web  >  Directives de développement CSS et Sass (SCSS)

Directives de développement CSS et Sass (SCSS)

高洛峰
高洛峰original
2017-02-28 13:46:021930parcourir

Cet article présente principalement les spécifications de codage front-end (4) - Spécifications de développement CSS et Sass (SCSS). Les amis dans le besoin peuvent s'y référer

ID et dénomination des classes <.>
Utilisez toujours des noms d'ID et de classe qui reflètent le but et l'utilisation de l'élément, ou d'autres noms communs. Au lieu d’apparences et de noms obscurs.

Les noms spécifiques et reflétant le but de l'élément doivent être préférés, car ils sont les plus compréhensibles et les moins susceptibles de changer.

Les noms communs ne sont que des noms alternatifs pour plusieurs éléments. Ils sont identiques à leurs éléments frères et n'ont aucune signification particulière.
Distinguez-les afin qu'ils aient une signification particulière et soient généralement nécessaires comme « aides ».

Bien que la sémantique des noms et des identifiants de classe n'ait aucune signification pratique pour l'analyse informatique,
Les noms sémantiques sont généralement le bon choix car les informations qu'ils représentent ne contiennent pas de limitations de performances.

Déconseillé

.fw-800 {
  font-weight: 800;
}
 
.red {
  color: red;
}

Recommandé

.heavy {
  font-weight: 800;
}
 
.important {
  color: red;
}

Évitez d'utiliser des identifiants le cas échéant
En général, les identifiants ne doivent pas être appliqués aux styles.
Les styles d'ID ne peuvent pas être réutilisés et vous ne pouvez utiliser l'ID qu'une seule fois par page.
La seule utilisation efficace de l'identification est de déterminer la position dans une page Web ou dans l'ensemble d'un site.
Cependant, vous devriez toujours envisager d'utiliser class au lieu de id, sauf si vous ne l'utilisez qu'une seule fois.

Déconseillé

#content .title {
  font-size: 2em;
}

Recommandé

.content .title {
  font-size: 2em;
}

Un autre argument contre l'utilisation des identifiants est que les sélecteurs contenant des identifiants sont très pondérés.

Un sélecteur contenant un seul identifiant a un poids plus élevé qu'un sélecteur contenant 1000 noms de classe, ce qui le rend bizarre.

// 这个选择器权重高于下面的选择器
#content .title {
  color: red;
}
 
// than this selector!
html body p.content.news-content .title.content-title.important {
  color: blue;
}

Évitez les noms de balises dans les sélecteurs CSS
Des noms clairs et précis doivent être utilisés lors de la création de sélecteurs et noms de classes sémantiques. N'utilisez pas de sélecteurs de balises. C'est plus facile à maintenir si vous ne vous souciez que des noms de vos classes
et non de vos éléments de code.

Dans une perspective de séparation, les balises/sémantiques HTML ne doivent pas être allouées dans la couche de présentation.
Il peut s'agir d'une liste ordonnée qui doit être remplacée par une liste non ordonnée, ou d'un p qui sera converti en article.
Si vous utilisez uniquement des noms de classe significatifs,
et n'utilisez pas de sélecteurs d'éléments, il vous suffit alors de modifier votre balisage HTML, pas votre CSS.

Déconseillé

p.content > header.content-header > h2.title {
  font-size: 2em;
}

Recommandé

.content > .content-header > .title {
  font-size: 2em;
}

Soyez aussi précis que possible
De nombreux développeurs front-end n'utilisent pas de sous-sélecteurs directs lors de l'écriture de chaînes de sélecteurs (remarque : la différence entre les sous-sélecteurs directs et les sélecteurs descendants).
Parfois, cela peut entraîner des problèmes de conception douloureux et peut parfois consommer des performances.
Cependant, c’est de toute façon une très mauvaise pratique.
Si vous n'écrivez pas un sélecteur très général qui doit correspondre à la fin du DOM, vous devriez toujours envisager des sous-sélecteurs directs.

Considérez le DOM suivant :

<article class="content news-content">
  <span class="title">News event</span>
  <p class="content-body">
    <p class="title content-title">
      Check this out
    </p>
 
    <p>This is a news article content</p>
 
    <p class="teaser">
      <p class="title">Buy this</p>
      <p class="teaser-content">Yey!</p>
    </p>
  </p>
</article>

Le CSS suivant sera appliqué aux trois éléments qui ont la classe title.

Ensuite, pour résoudre les différents styles sous la classe title sous la classe content et la classe title sous la classe teaser, cela nécessitera des sélecteurs plus précis pour réécrire à nouveau leurs styles.

Déconseillé

.content .title {
  font-size: 2rem;
}

Recommandé

.content > .title {
  font-size: 2rem;
}
 
.content > .content-body > .title {
  font-size: 1.5rem;
}
 
.content > .content-body > .teaser > .title {
  font-size: 1.2rem;
}

Propriétés des abréviations
CSS fournit diverses propriétés d'abréviation (telles que la police) qui doivent être utilisées autant que possible, même lorsqu'une seule valeur est définie.

L'utilisation d'attributs abrégés est très utile pour l'efficacité et la lisibilité du code.

Déconseillé

Code CSS :

border-top-style: none;
font-family: palatino, georgia, serif;
font-size: 100%;
line-height: 1.6;
padding-bottom: 2em;
padding-left: 1em;
padding-right: 1em;
padding-top: 0;

Recommandé


Code CSS :

border-top: 0;
font: 100%/1.6 palatino, georgia, serif;
padding: 0 1em 2em;

0 et l'unité
Omettez l'unité après la valeur "0". N'utilisez pas d'unités après une valeur 0 à moins qu'il n'y ait une valeur.
Déconseillé

Code CSS :

padding-bottom: 0px;
margin: 0em;

Recommandé


Code CSS :

padding-bottom: 0;
margin: 0;

Notation hexadécimale

Utilisez la notation hexadécimale à 3 caractères lorsque cela est possible.

Les valeurs de couleur permettent cette représentation,
Une représentation hexadécimale plus courte à 3 caractères.

Utilisez toujours des nombres hexadécimaux minuscules.

Déconseillé

color: #FF33AA;

Recommandé

color: #f3a;

Séparateur pour l'ID et le nom de la classe
Utilisez un trait d'union (dièse) pour séparer les mots dans l'ID et le nom de la classe. Pour améliorer la compréhension de la leçon, n'utilisez aucun caractère (y compris aucun) autre que des traits d'union (tirets) pour relier les mots et les abréviations dans le sélecteur.

De plus, en standard, le sélecteur d'attribut par défaut reconnaît les traits d'union (tirets) comme séparateurs pour les mots [attribut|=valeur],
il est donc préférable de s'en tenir aux traits d'union comme séparateur.

Déconseillé

.demoimage {}
.error_status {}

Recommandé


#video-id {}
.ads-sample {}

Hacks

避免用户代理检测以及CSS“hacks” – 首先尝试不同的方法。通过用户代理检测或特殊的CSS滤镜,变通的方法和 hacks 很容易解决样式差异。为了达到并保持一个有效的和可管理的代码库,这两种方法都应该被认为是最后的手段。换句话说,从长远来看,用户代理检测和hacks
会伤害项目,作为项目往往应该采取阻力最小的途径。也就是说,轻易允许使用用户代理检测和hacks 以后将过于频繁。

声明顺序

这是一个选择器内书写CSS属性顺序的大致轮廓。这是为了保证更好的可读性和可扫描重要。

作为最佳实践,我们应该遵循以下顺序(应该按照下表的顺序):

结构性属性:
display
position, left, top, right etc.
overflow, float, clear etc.
margin, padding
表现性属性:
background, border etc.
font, text
不推荐

.box {
  font-family: &#39;Arial&#39;, sans-serif;
  border: 3px solid #ddd;
  left: 30%;
  position: absolute;
  text-transform: uppercase;
  background-color: #eee;
  right: 30%;
  isplay: block;
  font-size: 1.5rem;
  overflow: hidden;
  padding: 1em;
  margin: 1em;
}

推荐

.box {
  display: block;
  position: absolute;
  left: 30%;
  right: 30%;
  overflow: hidden;
  margin: 1em;
  padding: 1em;
  background-color: #eee;
  border: 3px solid #ddd;
  font-family: &#39;Arial&#39;, sans-serif;
  font-size: 1.5rem;
  text-transform: uppercase;
}

声明结束

为了保证一致性和可扩展性,每个声明应该用分号结束,每个声明换行。

不推荐

css 代码:
.test {
  display: block; height: 100px
}

推荐

css 代码:

.test {
  display: block;
  height: 100px;
}

属性名结束

属性名的冒号后使用一个空格。出于一致性的原因,
属性和值(但属性和冒号之间没有空格)的之间始终使用一个空格。

不推荐

css 代码:

h3 {
  font-weight:bold;
}

推荐

css 代码:
h3 {
  font-weight: bold;
}

选择器和声明分离

每个选择器和属性声明总是使用新的一行。

不推荐

css 代码:

a:focus, a:active {
  position: relative; top: 1px;
}

推荐

css 代码:

h1,
h2,
h3 {
  font-weight: normal;
  line-height: 1.2;
}

规则分隔

规则之间始终有一个空行(双换行符)分隔。

推荐

css 代码:

html {
  background: #fff;
}
 
body {
  margin: auto;
  width: 50%;
}

CSS引号

属性选择器或属性值用双引号(””),而不是单引号(”)括起来。
URI值(url())不要使用引号。

不推荐

css 代码:

@import url(&#39;//cdn.com/foundation.css&#39;);
 
html {
  font-family: &#39;open sans&#39;, arial, sans-serif;
}
 
body:after {
  content: &#39;pause&#39;;
}

推荐

css 代码:

@import url(//cdn.com/foundation.css);
 
html {
  font-family: "open sans", arial, sans-serif;
}
 
body:after {
  content: "pause";
}

选择器嵌套 (SCSS)

在Sass中你可以嵌套选择器,这可以使代码变得更清洁和可读。嵌套所有的选择器,但尽量避免嵌套没有任何内容的选择器。
如果你需要指定一些子元素的样式属性,而父元素将不什么样式属性,
可以使用常规的CSS选择器链。
这将防止您的脚本看起来过于复杂。

不推荐

css 代码:

// Not a good example by not making use of nesting at all
.content {
  display: block;
}
 
.content > .news-article > .title {
  font-size: 1.2em;
}

不推荐

css 代码:

// Using nesting is better but not in all cases
// Avoid nesting when there is no attributes and use selector chains instead
.content {
  display: block;
 
  > .news-article {
    > .title {
      font-size: 1.2em;
    }
  }
}

推荐

css 代码:

// This example takes the best approach while nesting but use selector chains where possible
.content {
  display: block;
 
  > .news-article > .title {
    font-size: 1.2em;
  }
}

嵌套中引入 空行 (SCSS)

嵌套选择器和CSS属性之间空一行。

不推荐

css 代码:

.content {
  display: block;
  > .news-article {
    background-color: #eee;
    > .title {
      font-size: 1.2em;
    }
    > .article-footnote {
      font-size: 0.8em;
    }
  }
}

推荐

css 代码:

.content {
  display: block;
 
  > .news-article {
    background-color: #eee;
 
    > .title {
      font-size: 1.2em;
    }
 
    > .article-footnote {
      font-size: 0.8em;
    }
  }
}

上下文媒体查询(SCSS)

在Sass中,当你嵌套你的选择器时也可以使用上下文媒体查询。
在Sass中,你可以在任何给定的嵌套层次中使用媒体查询。
由此生成的CSS将被转换,这样的媒体查询将包裹选择器的形式呈现。

这技术非常方便,
有助于保持媒体查询属于的上下文。

第一种方法这可以让你先写你的手机样式,然后在任何你需要的地方
用上下文媒体查询以提供桌面样式。

不推荐

css 代码:

// This mobile first example looks like plain CSS where the whole structure of SCSS is repeated
// on the bottom in a media query. This is error prone and makes maintenance harder as it&#39;s not so easy to relate
// the content in the media query to the content in the upper part (mobile style)
 
.content-page {
  font-size: 1.2rem;
 
  > .main {
    background-color: whitesmoke;
 
    > .latest-news {
      padding: 1rem;
 
      > .news-article {
        padding: 1rem;
 
        > .title {
          font-size: 2rem;
        }
      }
    }
 
    > .content {
      margin-top: 2rem;
      padding: 1rem;
    }
  }
 
  > .page-footer {
    margin-top: 2rem;
    font-size: 1rem;
  }
}
 
@media screen and (min-width: 641px) {
  .content-page {
    font-size: 1rem;
 
    > .main > .latest-news > .news-article > .title {
      font-size: 3rem;
    }
 
    > .page-footer {
      font-size: 0.8rem;
    }
  }
}


推荐

css 代码:

// This is the same example as above but here we use contextual media queries in order to put the different styles
// for different media into the right context.
 
.content-page {
  font-size: 1.2rem;
 
  @media screen and (min-width: 641px) {
    font-size: 1rem;
  }
 
  > .main {
    background-color: whitesmoke;
 
    > .latest-news {
      padding: 1rem;
 
      > .news-article {
        padding: 1rem;
 
        > .title {
          font-size: 2rem;
 
          @media screen and (min-width: 641px) {
            font-size: 3rem;
          }
        }
      }
    }
 
    > .content {
      margin-top: 2rem;
      padding: 1rem;
    }
  }
 
  > .page-footer {
    margin-top: 2rem;
    font-size: 1rem;
 
    @media screen and (min-width: 641px) {
      font-size: 0.8rem;
    }
  }
}

嵌套顺序和父级选择器(SCSS)

当使用Sass的嵌套功能的时候,
重要的是有一个明确的嵌套顺序,
以下内容是一个SCSS块应具有的顺序。

当前选择器的样式属性
父级选择器的伪类选择器 (:first-letter, :hover, :active etc)
伪类元素 (:before and :after)
父级选择器的声明样式 (.selected, .active, .enlarged etc.)
用Sass的上下文媒体查询
子选择器作为最后的部分
The following example should illustrate how this ordering will achieve a clear structure while making use of the Sass parent selector.

Recommended

css 代码:

.product-teaser {
  // 1. Style attributes
  display: inline-block;
  padding: 1rem;
  background-color: whitesmoke;
  color: grey;
 
  // 2. Pseudo selectors with parent selector
  &:hover {
    color: black;
  }
 
  // 3. Pseudo elements with parent selector
  &:before {
    content: "";
    display: block;
    border-top: 1px solid grey;
  }
 
  &:after {
    content: "";
    display: block;
    border-top: 1px solid grey;
  }
 
  // 4. State classes with parent selector
  &.active {
    background-color: pink;
    color: red;
 
    // 4.2. Pseuso selector in state class selector
    &:hover {
      color: darkred;
    }
  }
 
  // 5. Contextual media queries
  @media screen and (max-width: 640px) {
    display: block;
    font-size: 2em;
  }
 
  // 6. Sub selectors
  > .content > .title {
    font-size: 1.2em;
 
    // 6.5. Contextual media queries in sub selector
    @media screen and (max-width: 640px) {
      letter-spacing: 0.2em;
      text-transform: uppercase;
    }
  }
}


更多CSS 和 Sass (SCSS) 开发规范相关文章请关注PHP中文网!


Déclaration:
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