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

理論的な基礎が必要であり、実践は理論を改善し、理解するための方法です。両方とも同じように重要です。設計者と開発者が 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 までご連絡ください。
@KeyFrames CSS:最も使用されているトリック@KeyFrames CSS:最も使用されているトリックMay 08, 2025 am 12:13 AM

@keyframesispopularduetoitsversitility andpowerincreatingsmoothcssanimations.keytricksinclude:1)defingsmoothtransitionsbetweenstates、2)AnimatingMultipleProperiessimally、3)3)bendorprefixesforbrows -compativity、4)組み合わせwithjavasfo

CSSカウンター:自動番号の包括的なガイドCSSカウンター:自動番号の包括的なガイドMay 07, 2025 pm 03:45 PM

csScounterSareSareusedTomageautomaticinginginwebdesigns.1)それらは、コンテンツ、リスト、および積極的なものを使用することができます

スクロール駆動型のアニメーションを使用したモダンなスクロールシャドウスクロール駆動型のアニメーションを使用したモダンなスクロールシャドウMay 07, 2025 am 10:34 AM

特にモバイルデバイスでは、スクロールシャドウを使用することは、Chrisが以前にカバーした微妙なUXです。 Geoffは、アニメーションタイムラインプロパティを使用する新しいアプローチをカバーしました。これがさらに別の方法です。

画像マップを再検討します画像マップを再検討しますMay 07, 2025 am 09:40 AM

簡単に復習してみましょう。画像マップはHTML 3.2に戻ります。ここで、最初にサーバー側マップを使用してから、マップとエリア要素を使用して画像上でクリック可能な領域を定義したクライアント側マップをマップしました。

開発者:すべての開発者の調査開発者:すべての開発者の調査May 07, 2025 am 09:30 AM

State of Devsの調査は現在、参加に対して開かれており、以前の調査とは異なり、コードを除くすべてをカバーしています:キャリア、職場だけでなく、健康、趣味などもあります。 

CSSグリッドとは何ですか?CSSグリッドとは何ですか?Apr 30, 2025 pm 03:21 PM

CSSグリッドは、複雑で応答性の高いWebレイアウトを作成するための強力なツールです。設計を簡素化し、アクセシビリティを向上させ、古い方法よりも多くの制御を提供します。

CSS Flexboxとは何ですか?CSS Flexboxとは何ですか?Apr 30, 2025 pm 03:20 PM

記事では、レスポンシブデザインにおけるスペースの効率的なアラインメントと分布のためのレイアウト方法であるCSS FlexBoxについて説明します。 FlexBoxの使用量を説明し、CSSグリッドと比較し、ブラウザのサポートを詳細に説明します。

CSSを使用してWebサイトを応答するにはどうすればよいですか?CSSを使用してWebサイトを応答するにはどうすればよいですか?Apr 30, 2025 pm 03:19 PM

この記事では、ビューポートメタタグ、柔軟なグリッド、流体メディア、メディアクエリ、相対ユニットなど、CSSを使用してレスポンシブWebサイトを作成するための手法について説明します。また、CSSグリッドとフレックスボックスを使用してカバーし、CSSフレームワークを推奨しています

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衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強力な PHP 統合開発環境

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

SublimeText3 英語版

SublimeText3 英語版

推奨: Win バージョン、コードプロンプトをサポート!

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 プラットフォームで実行できます。