suchen
HeimWeb-FrontendCSS-TutorialCSS Architektur Block-Element-Modifier (BEM)-SitePoint

BEM (Blockelementmodifier) ​​ist eine Front-End-Entwicklungsmethode, eine Namenskonvention und eine Reihe von zugehörigen Tools. Es stammt aus Yandex und wurde für die effiziente Entwicklung großer Teams entwickelt. Diese Erklärung konzentriert sich auf das Kernkonzept und das Benennungssystem.

BEM fördert das Anzeigen von Websites als Sammlungen wiederverwendbarer Komponentenblöcke, die für die Erstellung von Schnittstellen kombinierbar sind. Ein Block ist ein Website -Abschnitt (Header, Fußzeile, Seitenleiste usw.), wie in Abbildung 2.3 dargestellt. Beachten Sie, dass sich "Block" hier auf HTML -Seitensegmente bezieht.

CSS Architecture Block-Element-Modifier (BEM) - SitePoint

Abbildung 2.3. Eine Homepage kann Header-, Haupt- und Fußzeilenblöcke umfassen.

Blöcke können nisten. Beispielsweise kann ein Headerblock Logo-, Navigations- und Suchformularblöcke enthalten (Abbildung 2.4). Eine Fußzeile könnte einen Sitemap -Block enthalten.

CSS Architecture Block-Element-Modifier (BEM) - SitePoint

Abbildung 2.4. Ein Headerblock umfasst Logo, Navigation und Suchblöcke.

Elemente sind körniger als Blöcke. Wie in der BEM-Dokumentation heißt es: "Ein Element ist Teil eines Blocks, der eine bestimmte Funktion ausführt. Elemente sind kontextabhängig; sie sind nur in ihrem übergeordneten Block sinnvoll."

Ein Suchformularblock enthält beispielsweise ein Texteingangselement und ein Schaltflächenelement (Abbildung 2.5). Hier bezieht sich "Element" auf Designelemente, nicht auf HTML -Elemente.

CSS Architecture Block-Element-Modifier (BEM) - SitePoint

Abbildung 2.5. Ein Suchblock mit Texteingabe- und Senden -Schaltflächenelementen.

Ein Hauptinhaltsblock kann einen Artikellistenblock enthalten, der wiederum Artikel -Promo -Blöcke enthält. Jeder Promo -Block könnte Bild-, Auszugs- und "Lesen Sie mehr" Elemente (Abbildung 2.6).

CSS Architecture Block-Element-Modifier (BEM) - SitePoint

Abbildung 2.6. Ein Werbeblock für einen Website -Artikel.

Blöcke und Elemente bilden den Kern der Namenskonvention von BEM:

  • Blocknamen müssen eindeutig projektweit sein.
  • Elementnamen müssen innerhalb eines Blocks eindeutig sein.
  • Blockvariationen (z. B. ein dunkles Suchfeld) Verwenden Sie Modifikatoren im Klassennamen.

Block- und Elementnamen werden durch zwei Unterstriche getrennt (__). Modifikatoren werden von zwei Bindestrichen von Block/Elementnamen getrennt (--).

Hier ist ein BEM-Suchformular Beispiel:

<div class="search">
  <div class="search__wrapper">
    <label for="s" class="search__label">Search for:</label>
    <input type="text" id="s" class="search__input" />
    <input type="submit" class="search__submit" value="Search" />
  </div>
</div>

Eine dunkle Version:

<div class="search search--inverse">
  <div class="search__wrapper search__wrapper--inverse">
    <label for="s" class="search__label search__label--inverse">Search for:</label>
    <input type="text" id="s" class="search__input search__input--inverse" />
    <input type="submit" class="search__submit search__submit--inverse" value="Search" />
  </div>
</div>

entsprechende CSS:

<div class="search">
  <div class="search__wrapper">
    <label for="s" class="search__label">Search for:</label>
    <input type="text" id="s" class="search__input" />
    <input type="submit" class="search__submit" value="Search" />
  </div>
</div>

im Markup und CSS sind search--inverse und search__label--inverse Klassen hinzugefügt, nicht Ersatz. Es werden nur Klassenauswahl verwendet; Kinder- und Nachkomme -Selektoren sind erlaubt, sollten aber auch Klassen ansprechen. Element- und ID -Selektoren werden vermieden. Dies hält die Selektorspezifität niedrig, verhindert Nebenwirkungen und macht CSS unabhängig von Markup -Mustern. Eindeutige Block- und Elementnamen verhindern Benennungskonflikte. Zu den Vorteilen gehören:

  • Verbesserte Code -Lesbarkeit und -verständnis für neue Teammitglieder.
  • erhöhte Teamproduktivität.
  • Reduzierte Namenskollisionen und Nebenwirkungen.
  • CSS Unabhängigkeit von Markup.
  • hohe CSS -Wiederverwendbarkeit.

BEMs Bereich geht über diesen Überblick hinaus. Die offizielle BEM -Website enthält umfassende Details, Tools und Tutorials. "Get Bem" ist eine weitere hervorragende Ressource für die Namenskonvention.

(Der häufig gestellte Fragen wird weggelassen, da es sich um eine Wiederholung der bereits vorhandenen Informationen handelt und die Länge des Ausgangs erheblich erhöht, ohne neue Inhalte hinzuzufügen.)

Das obige ist der detaillierte Inhalt vonCSS Architektur Block-Element-Modifier (BEM)-SitePoint. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
@Keyframes vs CSS Übergänge: Was ist der Unterschied?@Keyframes vs CSS Übergänge: Was ist der Unterschied?May 14, 2025 am 12:01 AM

@KeyFramesandcsStransitionSdifferinComplexity:@keyFramesAllowsfordetailedanimationsequenzen, whilecsStransitionShandleSmplestatechanges.USecsStransitionsForHovereffectSlikeButtonColorchanges sowie@keyframesforintricateanimationslikerotierungen.

Verwenden von Seiten CMS für statische Site Content ManagementVerwenden von Seiten CMS für statische Site Content ManagementMay 13, 2025 am 09:24 AM

Ich weiß, ich weiß: Es gibt eine Menge von Content -Management -Systemoptionen, und während ich mehrere getestet habe, war keiner wirklich derjenige, den Sie wirklich wissen? Seltsame Preismodelle, schwierige Anpassungen, einige werden sogar ein Ganzes &

Die ultimative Anleitung zum Verknüpfen von CSS -Dateien in HTMLDie ultimative Anleitung zum Verknüpfen von CSS -Dateien in HTMLMay 13, 2025 am 12:02 AM

Das Verknüpfen von CSS -Dateien mit HTML kann durch die Verwendung von Elementen in einem HTML erreicht werden. 1) Verwenden Sie Tags, um lokale CSS -Dateien zu verknüpfen. 2) Mehrere CSS -Dateien können durch Hinzufügen mehrerer Tags implementiert werden. 3) Externe CSS -Dateien verwenden absolute URL -Links wie z. 4) Stellen Sie die korrekte Verwendung von Dateipfaden und CSS -Dateiladeauftrag sicher und optimieren Sie die Leistung können mit CSS -Präprozessor zusammengeführt werden, um Dateien zu verschmelzen.

CSS Flexbox vs Grid: Eine umfassende ÜberprüfungCSS Flexbox vs Grid: Eine umfassende ÜberprüfungMay 12, 2025 am 12:01 AM

Die Auswahl von Flexbox oder Grid hängt von den Layoutanforderungen ab: 1) Flexbox ist für eindimensionale Layouts wie die Navigationsleiste geeignet. 2) Das Gitter eignet sich für zweidimensionale Layouts wie Zeitschriftenlayouts. Die beiden können im Projekt verwendet werden, um den Layout -Effekt zu verbessern.

So füge CSS -Dateien ein: Methoden und Best PracticesSo füge CSS -Dateien ein: Methoden und Best PracticesMay 11, 2025 am 12:02 AM

Der beste Weg, um CSS -Dateien einzubeziehen, besteht darin, Tags zu verwenden, um externe CSS -Dateien in den HTML -Teil einzuführen. 1. Verwenden Sie Tags, um externe CSS -Dateien einzuführen, wie z. 2. Für kleine Anpassungen können Inline -CSS verwendet werden, sollten jedoch mit Vorsicht verwendet werden. 3. Große Projekte können CSS -Präprozessoren wie SASS oder weniger verwenden, um andere CSS -Dateien über @import zu importieren. 4. Für die Leistung sollten CSS -Dateien zusammengeführt und CDN verwendet und mit Tools wie CSSNano komprimiert werden.

Flexbox vs Grid: Soll ich sie beide lernen?Flexbox vs Grid: Soll ich sie beide lernen?May 10, 2025 am 12:01 AM

Ja, youShouldlearnbothflexBoxandgrid.1) FlexBoxiSidealfore-dimensional, flexibelayoutslikenAvigationMenus.2) GridexcelStwo-dimensional, komplexDesignsuchasmagazinelayouts.3) Kombininierungs-Botenhances-Flexible-und-und -Anteilungskraft, und -forsfossivität,

Orbitalmechanik (oder wie ich eine CSS -Keyframes -Animation optimiert habe)Orbitalmechanik (oder wie ich eine CSS -Keyframes -Animation optimiert habe)May 09, 2025 am 09:57 AM

Wie sieht es aus, Ihren eigenen Code neu zu gestalten? John Rhea nimmt eine alte CSS -Animation auseinander, die er geschrieben hat, und geht durch den Denkprozess der Optimierung.

CSS -Animationen: Ist es schwierig, sie zu erstellen?CSS -Animationen: Ist es schwierig, sie zu erstellen?May 09, 2025 am 12:03 AM

CsSanimationsarenotinherenthardbutRequirePractICEANDUnDing-fordertofcsPropertiesandTimingfunktionen.1) StartwithsimpleanimationslikescalingabuttononoversKeyFrames.2) useaSingFunctionslikecubic-BezierForteffects, SuchasabouNects, SuchasabouNects,, zu

See all articles

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Nordhold: Fusionssystem, erklärt
4 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
Mandragora: Flüstern des Hexenbaum
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

MinGW – Minimalistisches GNU für Windows

MinGW – Minimalistisches GNU für Windows

Dieses Projekt wird derzeit auf osdn.net/projects/mingw migriert. Sie können uns dort weiterhin folgen. MinGW: Eine native Windows-Portierung der GNU Compiler Collection (GCC), frei verteilbare Importbibliotheken und Header-Dateien zum Erstellen nativer Windows-Anwendungen, einschließlich Erweiterungen der MSVC-Laufzeit zur Unterstützung der C99-Funktionalität. Die gesamte MinGW-Software kann auf 64-Bit-Windows-Plattformen ausgeführt werden.

Sicherer Prüfungsbrowser

Sicherer Prüfungsbrowser

Safe Exam Browser ist eine sichere Browserumgebung für die sichere Teilnahme an Online-Prüfungen. Diese Software verwandelt jeden Computer in einen sicheren Arbeitsplatz. Es kontrolliert den Zugriff auf alle Dienstprogramme und verhindert, dass Schüler nicht autorisierte Ressourcen nutzen.

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ist eine PHP/MySQL-Webanwendung, die sehr anfällig ist. Seine Hauptziele bestehen darin, Sicherheitsexperten dabei zu helfen, ihre Fähigkeiten und Tools in einem rechtlichen Umfeld zu testen, Webentwicklern dabei zu helfen, den Prozess der Sicherung von Webanwendungen besser zu verstehen, und Lehrern/Schülern dabei zu helfen, in einer Unterrichtsumgebung Webanwendungen zu lehren/lernen Sicherheit. Das Ziel von DVWA besteht darin, einige der häufigsten Web-Schwachstellen über eine einfache und unkomplizierte Benutzeroberfläche mit unterschiedlichen Schwierigkeitsgraden zu üben. Bitte beachten Sie, dass diese Software

Dreamweaver Mac

Dreamweaver Mac

Visuelle Webentwicklungstools

EditPlus chinesische Crack-Version

EditPlus chinesische Crack-Version

Geringe Größe, Syntaxhervorhebung, unterstützt keine Code-Eingabeaufforderungsfunktion