Css中bem书写规范

更新日期: 2019-07-23阅读: 2.8k标签: 规范

bem是基于组件的web开发方法。其思想是将用户界面分隔为独立的块,从而使开发复杂的UI界面变得更简单和快,且不需要粘贴复制便可复用现有代码。BEM由Block、Element、Modifier组成。选择器里用以下连接符扩展他们的关系:

  • `__:双下划线用来连接块和块的子元素
  • ` :仅作为连字符使用,连接块或元素或修饰符的多个单词(也可以直接写成驼峰式)
  • --:双中划线用来连接块或元素的状态(也可使用‘_’单下划线表示)

示例:

block-name_modifier-name
block-name__element-name--modifier-name
block-name_modifier-name--modifier-value
block-name__element-name--modifier-name--modifier-value


基本概念

Block(块)

代码片段可能被复用且这段代码不依赖其他组件即可用Block。块可以互相嵌套,可以嵌套任意多层。
特点:

  • 块的名称用于描述它的目的。如 menu、button
  • 块不能影响所在环境。这意味着不能为块设置margin或position
  • 只能使用class命名选择器,而不能使用标签或id选择器
  • 不依赖于页面内其他块或元素


Element(元素)

Element是Block的一部分,没有独立存在的意义。任何一个Element语义上是和Block绑定的。

特点:

  • 与块使用'__'连接。 如: block__item
  • 用于描述它的目的。如:item、text
  • 元素可以彼此嵌套,可以嵌套任意多层
  • 元素总是属于块的一部分。所以类似于block__item1__item2的命名是不合法的


Modifier(修饰符)

Modifier是Block或Element上的标记。使用它们来改变样式,行为或状态。与块或元素连接符为'--'。


应用

相对另外的Blocks定位Block

最好的方式是混合使用block和element。解决block上不能设置margin、position。

例:

<body>
    <!-- header and navigation-->
    <header>...</header>
    <!-- footer -->
    <footer>...</footer>
</body>
.page__header {
    padding: 20px;
}

.page__footer {
    padding: 50px;
}


Block内定位Elements

通过额外创建Block的子Element来定位嵌套。

例:

<body>
    <div>
      <!-- header and navigation-->
      <header>...</header>
      <!-- footer -->
      <footer>...</footer>
    </div>
</body>

.page__inner {
    margin-right: auto;
    margin-left: auto;
    width: 960px;
}

  

关于命名

选择器的命名必须完整且精确地描述它代表的BEM实体。

例:

.button {}
.button__icon {}
.button__text {}
.button_theme_islands {}

我们可直接指导我们在处理一个块元素。在html使用如:
<button>
    <span></span>
    <span>...</span>
</button>

而下面的css就很难让我们做出相同的判断:
.button {}
.icon {}
.text {}
.theme_islands {}

链接: https://fly63.com/article/detial/4330

web开发,前后分离接口规范

目前我们现在用的前后端分离模式属于第一阶段,下一阶段可以在前端工程化方面,对技术框架的选择、前端模块化重用方面,可多做考量。也就是要迎来“==前端为主的 MV* 时代==”。

js中箭头函数的编码规范,如何更好的使用箭头函数

当您必须使用匿名函数,请使用箭头函数表示法,它创建了一个在 this 上下文中执行的函数的版本,这通常是你想要的,而且这样的写法更为简洁。如果你有一个相当复杂的函数,你或许可以把逻辑部分转移到一个声明函数上。

用standard来管理JavaScript 代码规范

standard是一个开源的JS代码规范库,制定了所谓standard(标准)的JS代码规范,配合编辑器插件可以实时检查代码规范以及语法错误,通过执行命令检查代码规范以及语法错误,自动修复(可以直接修复的)不合规范的代码,使其符合规范

Web 前端开发代码规范(基础)

对于一个多人团队来说,制定一个统一的规范是必要的,因为个性化的东西无法产生良好的聚合效果,规范化可以提高编码工作效率,使代码保持统一的风格,以便于代码整合和后期维护。

Node.js的模块加载机制(CommonJS规范)

为了编写可维护的代码,我们把很多函数分组,分别放到不同的文件里,这样,每个文件包含的代码就相对较少,很多编程语言都采用这种组织代码的方式。在Node环境中,一个.js文件就称之为一个模块(module)

web前端js中ES6的规范写法

引号的使用,单引号优先(如果不是引号嵌套,不要使用双引号)、空格的使用问题:(关键字后 符号后 排版 函数 赋值符号= )等、不写没有使用过的变量,如果定义了一个变量,后来一直没有参与过运算,那么不应该定义这个变量...

编码规范_html代码规范化编写

嵌套的节点应该缩进;在属性上,使用双引号,不要使用单引号;属性名全小写,用中划线做分隔符;不要在自动闭合标签结尾处使用斜线(HTML5 规范 指出他们是可选的);不要忽略可选的关闭标签;

CommonJS 规范中的 module、module.exports 区别

CommonJS规范规定,每个模块内部,module变量代表当前模块。这个变量是一个对象,它的exports属性(即module.exports)是对外的接口。加载某个模块,其实是加载该模块的module.exports属性。module.exports属性表示当前模块对外输出的接口

W3C 代码标准规范

W3C通过设立领域(Domains)和标准计划(Activities)来组织W3C的标准活动,围绕每个标准计划,会设立相关的W3C工作组织(包括工作组、社区组、商务组等)。W3C会根据产业界的标准需求调整Domains和Activity的设置及相关的工作组设置。

css3代码书写规范

不要使用 @import 与 <link> 标签相比,@import 指令要慢很多,不光增加了额外的请求次数,还会导致不可预料的问题。CSS有些属性是可以缩写的,比如padding,margin,font等等,这样精简代码同时又能提高用户的阅读体验。

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!