ホームページ ウェブフロントエンド CSSチュートリアル CSS ルールカスケードの適用 CSS_Experience 交換で注意すべきいくつかのポイント

CSS ルールカスケードの適用 CSS_Experience 交換で注意すべきいくつかのポイント

May 16, 2016 pm 12:06 PM

理論的な基礎が必要であり、実践は理論を改善し、理解するための方法です。両方とも同じように重要です。設計者と開発者が 2 つのバランスを保てない場合、どちらの側を好むかに関係なく、左右どちらかで間違いを犯すことになります。 。しかし、私が話しているこの方法の実際の用途は何でしょうか。当然のことですが、角丸四角形を作成したり、列レイアウトを作成したり、文書の先頭に固定されたナビゲーション バーを提供したりすることはできません。このアルゴリズムの実際の応用は次のとおりです。 優れた css プログラミングの実践。これはマクロの実践であり、先ほど述べたミクロの実践と同じくらい重要ですが、習得するのははるかに困難です。

この記事は、優れた css プログラミング仕様をすべて網羅することを意図したものではありません。また、それが可能であるわけではありません。私が提供できるのは、css を記述するための個人的な仕様の概要だけです。これらの仕様はできるだけ近いものにしておきたいと考えています。 css の操作に可能です。

インライン css を使用しないでください
ユーザー スタイルはあなたの制御下にありません
重要なルールを使用しないでください
具体性に応じて css を下位から上位に記述してください
/>前 この 3 つの点は、私が話していることの焦点では​​ないので、一つずつ述べていきます。

インライン css の特殊性が最も高くなります。css ファイル内の属性がインライン css と競合する場合、css ファイル内の属性は無効になります。これは、デバッグだけを行うのとは異なります。 css ファイル内のスタイルの習慣が一致しません。インライン css も醜く、html ドキュメントにスタイルを挿入するため、放棄する必要があります。

ユーザーがユーザー スタイルを重要に設定した場合、css ルールをどのように記述しても、ユーザーの重要なステートメントをオーバーライドすることはできないため、すべてのユーザー スタイルをオーバーライドしようとしても無駄です。幸いなことに、これについてはもう考える必要はありません。

重要なルールは異常値です。これは私たちの通常の考え方と一致しません。css ルールの具体性と順序をどのように高めても、重要なルールはそれと競合するルールを上書きします。また、css ルールの慣習的なルールを破壊すると、デバッグに問題が生じます。重要なルールを使用してブラウザをハッキングしたい場合は、一意の要素を指すセレクターでルールを適用する必要があります。 (ps. hack はあまりにも醜いので、ソリューションで最後に検討すべきです。)

最後のポイントは、具体性の低いものから高いものまで css を記述する方法です。

鍵となるのはモジュール式 css です。

グローバル css を追加します
現在のページに統合 css を追加します
ページをいくつかのモジュールに分割します
それぞれの異なるモジュールで id フックを使用し、モジュールでクラス フックを使用します同じモジュール
各モジュールに統一 css を追加
各モジュールを複数のサブモジュールに分割し、ステップ 4 に戻ってスタイルの追加が完了するまでループを開始します。
優れた css を書くことは設計の問題であり、実装の問題ではありません。まず、特異性が非常に低いグローバル css コンテンツ (一般的に使用されるreset.css) を作成する必要があります。これは、web サイト全体のすべてのページのデフォルトのスタイルです。

他のページとは背景が異なるページなど、ページに独自の統一スタイルがある場合は、ページに id を追加し、その id の下に現在のページの統一 css を記述することができます。

body#special{ 
    background-color:black; 
}
ログイン後にコピー

統一スタイルを作成した後、ページをいくつかのモジュールに分割します。これらのモジュールが基本的に同じスタイルを持つ場合は、クラス フックを使用します。スタイルが異なる場合は、同じ場合は id フックを使用し、今後モジュールに分割するたびにこの原則に従う必要があります。クラスはあまり具体的ではないため、明らかに似ているモジュールでない場合はクラスを使用すべきではありません。通常、id の名前はモジュールの名前として使用できます。頭やお尻など。 id セレクターはカスケードにおいて重要な役割を果たします。id は排他的であり、高い特異性を持っているため、css ルールが誤ってオーバーライドされるのを防ぐことができます。

特定のモジュールに統一 css がある場合、id セレクターを使用して現在のモジュールに統一スタイルを記述する必要があります。

#head p{ 
    color:red; 
}
ログイン後にコピー

クラス フックを追加するときは、クラス名の最初の部分として親モジュール (またはページ自体) の id を使用することをお勧めします。独立したページ (body#special) を追加する場合、モジュールをページのモジュールに分割した後、ページのモジュールにspecial_head、special_bottom などの名前を付ける必要があります。

または、一部のページモジュールでクラスフックを使用する場合は、head_col などを使用する必要があります。この利点は、

#head .col{ 
    /* 头部中每一列的样式 */ 
}
ログイン後にコピー

を使用する必要がなく、

.head_col{ 
    /* 头部中每一列的样式 */ 
}
ログイン後にコピー

を直接使用できることです。名前の競合を心配する必要はありません。

モジュールの直下に id セレクターが追加された要素の場合、セレクターを直接使用して、名前の前に親モジュールの id を追加できます。

#head_navigator{ 
    /* 头部中导航栏的样式 */ 
}
ログイン後にコピー

モジュール型 css を実現するには、クロスモジュール css が表示されないようにする必要があります。良い原則は次のとおりだと思います。特定のスタイルのクロスモジュール機能が一目瞭然なので、クロスモジュール css は使用しないでください。 1 つの例外は、グローバル css またはモジュール内の統合 css です。一目でわかりにくく、スタイルが統一されていないものについては、サブモジュールごとに個別に定義することをお勧めします。これは、java プログラムを作成する際のオブジェクト指向設計と同じで、同じモジュールの css ルールをまとめ、わずかに異なる css ルールを完全に分離するために、モジュール間の相互依存性を減らす必要があります。これは保守が容易なだけでなく、 、ただし、css ルールが誤って上書きされるのを防ぐために、css を低い特異性から高い特異性まで書き込むことも保証します

上記は、カスケード css ルールを使用して css を適用するときに注意する必要がある点です_エクスペリエンス交換コンテンツ, 詳細 関連コンテンツについては、php 中国語 web サイト (www.php.cn) に注目してください。


このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホット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ヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

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

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Vue におけるプレースホルダーの意味 Vue におけるプレースホルダーの意味 May 07, 2024 am 09:57 AM

Vue.js では、placeholder 属性は、input 要素のプレースホルダー テキストを指定します。これは、ユーザーがコンテンツを入力していないときに表示され、入力のヒントや例を提供し、フォームのアクセシビリティを向上させます。その使用方法は、input 要素にプレースホルダー属性を設定し、CSS を使用して外観をカスタマイズすることです。ベスト プラクティスには、入力に関連すること、短く明確にすること、デフォルトのテキストを避けること、アクセシビリティを考慮することが含まれます。

jsでのスパンの意味は何ですか jsでのスパンの意味は何ですか May 06, 2024 am 11:42 AM

スパン タグは、テキストにスタイル、属性、または動作を追加できます。 色やフォント サイズなどのスタイルを追加するために使用されます。 idやclassなどの属性を設定します。クリック、ホバーなどの関連する動作。さらに処理または引用するためにテキストにマークを付けます。

jsでレムは何を意味しますか jsでレムは何を意味しますか May 06, 2024 am 11:30 AM

CSS の REM は、ルート要素 (html) のフォント サイズに対する相対単位です。次の特性があります: ルート要素のフォント サイズに相対し、親要素の影響を受けません。ルート要素のフォント サイズが変更されると、REM を使用する要素もそれに応じて調整されます。任意の CSS プロパティとともに使用できます。 REM を使用する利点は次のとおりです。 応答性: さまざまなデバイスや画面サイズでもテキストを読みやすい状態に保ちます。一貫性: Web サイト全体でフォント サイズが一貫していることを確認します。スケーラビリティ: ルート要素のフォント サイズを調整することで、グローバル フォント サイズを簡単に変更できます。

vueに画像を導入する方法 vueに画像を導入する方法 May 02, 2024 pm 10:48 PM

Vue に画像を導入するには、URL、require 関数、静的ファイル、v-bind ディレクティブ、CSS 背景画像の 5 つの方法があります。動的画像は Vue の計算プロパティまたはリスナーで処理でき、バンドルされたツールを使用して画像の読み込みを最適化できます。パスが正しいことを確認してください。そうでないと、読み込みエラーが表示されます。

jsのノードとは何ですか jsのノードとは何ですか May 07, 2024 pm 09:06 PM

ノードは、HTML 要素を表す JavaScript DOM 内のエンティティです。これらはページ内の特定の要素を表し、その要素にアクセスして操作するために使用できます。一般的なノード タイプには、要素ノード、テキスト ノード、コメント ノード、ドキュメント ノードなどがあります。 getElementById() などの DOM メソッドを通じて、ノードにアクセスし、プロパティの変更、子ノードの追加/削除、ノードの挿入/置換、ノードのクローン作成などの操作を行うことができます。ノードトラバーサルは、DOM 構造内を移動するのに役立ちます。ノードは、ページ コンテンツ、イベント処理、アニメーション、およびデータ バインディングを動的に作成するのに役立ちます。

ブラウザのプラグインは何語で書かれていますか? ブラウザのプラグインは何語で書かれていますか? May 08, 2024 pm 09:36 PM

ブラウザ プラグインは通常、次の言語で作成されます。 フロントエンド言語: JavaScript、HTML、CSS バックエンド言語: C++、Rust、WebAssembly その他の言語: Python、Java

Vueのrefとidは何をするのでしょうか? Vueのrefとidは何をするのでしょうか? May 02, 2024 pm 08:42 PM

Vue.js では、JavaScript で ref を使用して DOM 要素 (サブコンポーネントおよび DOM 要素自体にアクセス可能) を参照し、id を使用して HTML id 属性を設定します (CSS スタイル、HTML マークアップ、および JavaScript ルックアップに使用できます) )。

vscodeで不明な属性を設定する方法 vscodeで不明な属性を設定する方法 vscodeで不明な属性を設定する方法 vscodeで不明な属性を設定する方法 May 09, 2024 pm 02:43 PM

1. まず、左下隅にある設定アイコンを開き、設定オプションをクリックします。 2. 次に、ジャンプしたウィンドウで CSS 列を見つけます。 3. 最後に、不明なプロパティ メニューのドロップダウン オプションをエラー ボタンに変更します。 。

See all articles