BEM is a component-based approach to web development. The idea is to separate the user interface into independent blocks, making it easier and faster to develop complex UI interfaces, and to reuse existing code without copying and pasting. BEM consists of Block, Element, and Modifier. The following connectors are used in the selector to expand their relationship:
Example: block-name_modifier-name block-name__element-name--modifier-name block-name_modifier-name--modifier-value block-name__element-name--modifier-name--modifier-value Basic Concepts Block The code snippet may be reused and this code does not depend on other components, that is, Block can be used. Blocks can be nested within each other to any depth.
Element Element is a part of Block and has no independent existence. Any Element is semantically bound to a Block. Features:
Modifier Modifier is a tag on a Block or Element. Use them to change style, behavior, or state. The connector for blocks or elements is '--'. application Positioning a Block relative to other Blocks The best approach is to use a mix of blocks and elements. Solve the problem that margin and position cannot be set on block. example: <body class="page"> <!-- header and navigation--> <header class="header page__header">...</header> <!-- footer --> <footer class="footer page__footer">...</footer> </body> .page__header { padding: 20px; } .page__footer { padding: 50px; } Positioning Elements within a Block Nesting is achieved by creating additional child elements of Block. example: <body class="page"> <div class="page__inner"> <!-- header and navigation--> <header class="header">...</header> <!-- footer --> <footer class="footer">...</footer> </div> </body> .page__inner { margin-right: auto; margin-left: auto; width: 960px; } About naming Selector names must fully and accurately describe the BEM entity they represent. example: .button {} .button__icon {} .button__text {} .button_theme_islands {} We can directly instruct that we are dealing with a block element. Use in html like: <button class="button button_theme_islands"> <span class="button__icon"></span> <span class="button__text">...</span> </button> The following CSS makes it difficult for us to make the same judgment: .button {} .icon {} .text {} .theme_islands {} I adopted the BEM specification in my git project miniui and implemented BEM using sass. If you are interested, you can check it out: https://github.com/banyaner/miniui The above is the full content of this article. I hope it will be helpful for everyone’s study. I also hope that everyone will support 123WORDPRESS.COM. |
>>: JavaScript Sandbox Exploration
This question originated from a message on Nugget...
First of all, let's talk about the execution ...
The project scaffolding built with vue-cli has al...
Adding/removing classes to elements is a very com...
Brief description <br />In IE6 and 7, in a ...
This article uses examples to explain the princip...
This article shares the specific code of js to ac...
Preface: I wrote this because I helped my friend ...
Table of contents 1. Virtual Host 1.1 Virtual Hos...
Table of contents 1. Definition of stack 2. JS st...
Table of contents Two modules for using nginx for...
Table of contents background question Problem ana...
1. Pull the image First, execute the following co...
Recently, when I was working on a front-end vue.j...
Preface I once encountered a difficult problem. I...