検索
ホームページウェブフロントエンドhtmlチュートリアルフロントエンドコーディング仕様(4) -- CSSとSass(SCSS)仕様_html/css_WEB-ITnose

CSS および Sass (SCSS) スタイルのルール

ID およびクラスの名前付け

ID およびクラス (クラス) 名には、要素の目的と用途を反映した名前、またはその他の一般的な名前が常に使用されます。見た目や曖昧な名前の代わりに。

最も理解しやすく、変更される可能性が低いため、要素の目的を反映した具体的な名前を優先する必要があります。

共通名は複数の要素の代替名にすぎず、兄弟要素と同じであり、特別な意味はありません。
それらが特別な意味を持ち、通常は「ヘルパー」として必要とされるように区別します。

クラス名と ID のセマンティクスはコンピューターの解析にとって実際的な意味はありませんが、
セマンティクス名が表す情報にはパフォーマンスの制限が含まれていないため、通常はセマンティクス名が正しい選択となります。

推奨されません

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

推奨

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

ID の使用は合理的に避けてください

一般に、ID はスタイルに適用すべきではありません。
ID スタイルは再利用できず、ID はページごとに 1 回のみ使用できます。
ID でうまく機能する唯一のことは、Web ページまたはサイト全体内の位置を決定することです。
ただし、一度しか使用しない場合を除き、ID の代わりにクラスを使用することを常に検討する必要があります。

非推奨

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

推奨

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

ID の使用に対するもう 1 つの議論は、ID を含むセレクターの重みが高いということです。
ID を 1 つだけ含むセレクターは、1000 個のクラス名を含むセレクターよりも重みが高く、奇妙になります。

うろ覚えです

CSS セレクターではタグ名を使用しないでください

セレクターを構築するときは、明確で正確かつセマンティックなクラス名を使用する必要があります。タグセレクターは使用しないでください。 コード要素ではなくクラス名のみに注意すれば、保守が容易になります。

分離の観点から考えると、HTML タグ/セマンティクスはプレゼンテーション層に配置されるべきではありません。

それは、順序なしリストに変更する必要がある順序付きリスト、または記事に変換される div である可能性があります。
意味のあるクラス名のみを使用し、
要素セレクターを使用しない場合は、CSS ではなく HTML マークアップのみを変更する必要があります。

非推奨

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

推奨

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

できるだけ正確に

多くのフロントエンド開発者は、セレクター チェーンを記述するときに直接サブセレクターを使用しません (注: 直接サブセレクターと子孫セレクターの違い)。

場合によっては、これによりデザイン上の問題が発生し、パフォーマンスが低下する可能性があります。
ただし、いずれにせよ、これは非常に悪い習慣です。
DOM の末尾に一致する必要がある非常に一般的なセレクターを作成していない場合は、常に直接の子セレクターを考慮する必要があります。

次の DOM について考えてみましょう:

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

次の CSS は、title クラスを持つ 3 つの要素すべてに適用されます。

次に、コンテンツ クラスの下のタイトル クラスとティーザー クラスの下のタイトル クラスのさまざまなスタイルを解決するには、スタイルを再度書き直すためのより正確なセレクターが必要になります。

非推奨

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

推奨

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

略語プロパティ

CSS には、値が 1 つだけ設定されている場合でも、可能な限り使用する必要があるさまざまな略語プロパティ (フォントなど) が用意されています。

省略された属性の使用は、コードの効率性と読みやすさの点で非常に役立ちます。

非推奨

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

推奨

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;

0と単位

「0」値の後の単位を省略します。値がない限り、0 値の後に単位を使用しないでください。

非推奨

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

推奨

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

16進表記

可能な限り3文字の16進表記を使用してください。

色の値では、
より短い 3 文字の 16 進表記が可能です。

常に小文字の 16 進数を使用してください。

非推奨

padding-bottom: 0;margin: 0;

推奨

color: #FF33AA;

ID とクラス名の区切り文字

ID とクラス名の単語を区切るにはハイフン (ダッシュ) を使用します。レッスンの理解を促進するために、セレクター内の単語や略語を接続するためにハイフン (ダッシュ) 以外の文字 (何も使用しない場合も含む) を使用しないでください。

また、標準として、デフォルトの属性セレクターは単語 [属性|=値] の区切り文字としてハイフン (ダッシュ) を認識するため、

したがって、区切り文字としてはハイフンにこだわることが最善です。

非推奨 rree

推奨 rree

Hacks

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

声明顺序

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

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

  1. 结构性属性:

    1. display

    2. position, left, top, right etc.

    3. overflow, float, clear etc.

    4. margin, padding

  2. 表现性属性:

    1. background, border etc.

    2. font, text

不推荐

.box {  font-family: 'Arial', 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: 'Arial', sans-serif;  font-size: 1.5rem;  text-transform: uppercase;}

声明结束

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

不推荐

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

推荐

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

属性名结束

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

不推荐

h3 {  font-weight:bold;}

推荐

h3 {  font-weight: bold;}

选择器和声明分离

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

不推荐

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

推荐

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

规则分隔

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

推荐

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

CSS引号

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

不推荐

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

推荐

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

选择器嵌套 (SCSS)

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

不推荐

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

不推荐

// 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;    }  }}

推荐

// 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属性之间空一行。

不推荐

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

推荐

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

上下文媒体查询(SCSS)

在Sass中,当你嵌套你的选择器时也可以使用上下文媒体查询。
在Sass中,你可以在任何给定的嵌套层次中使用媒体查询。
由此生成的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'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;    }  }}

推荐

// 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块应具有的顺序。

  1. 当前选择器的样式属性

  2. 父级选择器的伪类选择器 (:first-letter, :hover, :active etc)

  3. 伪类元素 (:before and :after)

  4. 父级选择器的声明样式 (.selected, .active, .enlarged etc.)

  5. 用Sass的上下文媒体查询

  6. 子选择器作为最后的部分

The following example should illustrate how this ordering will achieve a clear structure while making use of the Sass parent selector.

Recommended

.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;    }  }}


声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
HTML、CSS、およびJavaScriptの理解:初心者向けガイドHTML、CSS、およびJavaScriptの理解:初心者向けガイドApr 12, 2025 am 12:02 AM

webdevelopmentReliesOnhtml、css、andjavascript:1)htmlStructuresContent、2)cssStylesit、および3)Javascriptaddsinteractivity、形成、

HTMLの役割:Webコンテンツの構造HTMLの役割:Webコンテンツの構造Apr 11, 2025 am 12:12 AM

HTMLの役割は、タグと属性を使用してWebページの構造とコンテンツを定義することです。 1。HTMLは、読みやすく理解しやすいようなタグを介してコンテンツを整理します。 2。アクセシビリティとSEOを強化するには、セマンティックタグなどを使用します。 3. HTMLコードの最適化により、Webページの読み込み速度とユーザーエクスペリエンスが向上する可能性があります。

HTMLとコード:用語を詳しく見るHTMLとコード:用語を詳しく見るApr 10, 2025 am 09:28 AM

htmlisaspecifictypeofcodefocuseduructuringwebcontent

HTML、CSS、およびJavaScript:Web開発者に不可欠なツールHTML、CSS、およびJavaScript:Web開発者に不可欠なツールApr 09, 2025 am 12:12 AM

HTML、CSS、およびJavaScriptは、Web開発の3つの柱です。 1。HTMLは、Webページ構造を定義し、などなどのタグを使用します。2。CSSは、色、フォントサイズなどのセレクターと属性を使用してWebページスタイルを制御します。

HTML、CSS、およびJavaScriptの役割:コアの責任HTML、CSS、およびJavaScriptの役割:コアの責任Apr 08, 2025 pm 07:05 PM

HTMLはWeb構造を定義し、CSSはスタイルとレイアウトを担当し、JavaScriptは動的な相互作用を提供します。 3人はWeb開発で職務を遂行し、共同でカラフルなWebサイトを構築します。

HTMLは初心者のために簡単に学ぶことができますか?HTMLは初心者のために簡単に学ぶことができますか?Apr 07, 2025 am 12:11 AM

HTMLは、簡単に学習しやすく、結果をすばやく見ることができるため、初心者に適しています。 1)HTMLの学習曲線はスムーズで簡単に開始できます。 2)基本タグをマスターして、Webページの作成を開始します。 3)柔軟性が高く、CSSおよびJavaScriptと組み合わせて使用​​できます。 4)豊富な学習リソースと最新のツールは、学習プロセスをサポートしています。

HTMLでの開始タグの例は何ですか?HTMLでの開始タグの例は何ですか?Apr 06, 2025 am 12:04 AM

Anexampleapalofastartingtaginhtmlis、それはaperginsaparagraph.startingtagsaresentionentientiontheyinitiateelements、definetheirtypes、およびarecrucialforurturingwebpagesandcontingthomedomを構築します。

CSSのフレックスボックスレイアウトを使用して、メニューの点線のラインセグメンテーション効果のセンターアラインメントを実現する方法は?CSSのフレックスボックスレイアウトを使用して、メニューの点線のラインセグメンテーション効果のセンターアラインメントを実現する方法は?Apr 05, 2025 pm 01:24 PM

メニューで点線のラインセグメンテーション効果を設計する方法は?メニューを設計するときは、通常、皿の名前と価格の間に左右に合わせることは難しくありませんが、真ん中の点線またはポイントはどうですか...

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SecLists

SecLists

SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強力な PHP 統合開発環境