BEM的用法是什么?BEM命名规则要注意哪些?
Admin 2022-03-23 群英技术资讯 1712 次浏览
这篇文章给大家分享的是有关BEM的内容。一些朋友可能对BEM是什么,BEM的用法等等不是很了解,因此本文就给大家详细介绍一下BEM,感兴趣的朋友就继续往下看吧。
什么是BEM
BEM(块,元素,修饰符)是基于组件的Web开发的一种前端命名方法论,主要针对CSS。其背后的想法是将用户界面分为独立的块。即使使用复杂的UI,这也使界面开发变得容易和快速,并且允许重用现有代码而无需复制和粘贴。
优势
怎么使用BEM
Block
一个功能独立的页面组件,可以重复使用
块不应影响其环境,这意味着您不应设置块的外部几何形状(边距)或位置
< div class = "header" > < div class = "red-text" >
Element
块的复合部分,不能单独使用
元素全名的结构为block-name__element-name
Search
一个元素始终是块的一部分,而不是另一个元素,因此元素名称不可定义为 block__elem1__elem2 的层次结构
SearchSearch
元素始终是一个块的一部分,您不应该与该块分开使用
SearchSearch
Modifier
定义块或元素的外观,状态或行为的实体
修饰符的两种类型
Boolean
修饰符全名的结构遵循以下模式:
Search
Key-value
修饰符全名的结构遵循以下模式:
Search
不能将修饰符与修饰的块或元素隔离使用。修饰符应更改实体的外观,行为或状态,而不是替换它
SearchSearch
在修饰符和元素名称中添加块名称的好处
什么时候应该用 BEM 格式
.hide {
display: none !important;
}
命名规范
双下划线风格
block-name__elem-name--mod-name--mod-val
CamelCase style
blockName-elemName_modName_modVal
React命名范式
BlockName-ElemName_modName_modVal
没有命名空间样式
_available
常用的CSS命名
例子
vant 组件 css 命名
使用的命名是双下划线风格:block-name__element-name--modifier-name
weui 组件 css 命名
使用的命名是 React命名风格:block-name__element-name_modifier-name
校验 BEM 规范工具
stylelint-selector-bem-pattern
以上就是BEM的用法及命名规范的介绍啦,有需要的朋友可以了解看看,希望本文对大家有帮助,想要了解更多BEM的内容,大家可以继续浏览群英网络其他相关的文章。
文本转载自脚本之家
相关阅读:
WebSocket是什么?PHP如何实现WebSocket?
websocket封装过程是什么?
react项目应该如何创建和部署?
用css写圆形镂空打孔效果的优惠券
CSS实现视差滚动的原理及方法是什么?
用CSS3怎样做红包的抖动动画效果?
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
在网页开发中,我们经常看到有人使用css background-position属性来做切图,为什么要使用cssSprite切图技术呢? css Sprite切图技术主要就是将多张图片放在一张图片里面,这有助于减少http网页请求,并且提高网页的性能,对SEO也有很大的帮助,css Sprite切
这篇文章给大家分享的是css伪类的分类及作用,小编觉得挺实用的,因此分享给大家做个参考。另外,下文还介绍了伪元素的分类及作用,以及CSS 伪类修改input选中样式的示例代码,感兴趣的朋友也可以了解看看。
一些朋友对innerHTML的使用比较好奇,但又找不到比较合适的方法,接下来的时间不妨看看爱站技术频道小编所整理的资料,或多或少能在工作中帮助到大家。
这篇文章给大家分享的是CSS选择器的使用,CSS中选择器主要分为:基本选择器、属性选择器、组合选择器与伪类选择器四个大类,下文介绍了他们的使用,文中的示例代码介绍得很详细,有需要的朋友可以参考,接下来就跟随小编一起学习一下吧。
像素风的游戏是80,90后的童年,像素风本身就是由极度简单的元素构成极度复杂的画面,本文介绍了Canvas绘制像素风图片,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008