怎么在CSS中利用methodologies实现模块化

    

css:

.header {
}
.menu {
}
.menu-item {
}
.item.active {
}
.action {
}
.btn {
}
.btn-login {
}
.btn-register{
}

2、BEM

BEM - Block Element Modfier(块元素编辑器)。诞生于2009年。

(1)内容

BEM 包括三个:

  • Block - 块,如 header

  • Element - 子元素,如 块menu 下的 item

  • Modfier - 状态,如.current、.active

(2)规则

1、命名规范

  • -中划线 :仅作为连字符使用,表示某个块或者某个子元素的多单词之间的连接记号。

  • __ 双下划线:用来连接块和块的子元素。

  • -- 双中划线:用来描述一个块或者块的子元素的一种状态。

在某些公司(如腾讯)的规范里,双中划线被单下划线(_)替代。

例如:.block-name__element--modifier

demo - html:


         
            1
            2
            3
        
        
            login
            register
        
    

demo - less:

.header {
    &__menu {}
    &__menu-item {}
    &__action {}
    &__btn {  
        &--login {}
        &--register {}
    }    
}

2、避免嵌套

BEM 最多只有 B+E+M 三级。

所以请避免 .block__el1__el2 的格式,直接改为 .block_el2

这里的 block 就很像命名空间了。

(3)利弊

好处:

缺点:

其他:

BEM 命名会使得 Class 类名变长,但经过 gzip 压缩后这个带宽开销可以忽略不计。

BEM是不允许用标签选择器的,哪怕最简单的 li 也得写成 .menu-item。

(4)实践

饿了么的框架elementUI就是BEM的一种,或者你也可以研究网站company.yandex.ru/。

3、SMACSS

SMACSS(Scalable & Modular Architecture CSS ,即 CSS 的可扩展性和模块化架构)。Jonathan Snook 于 2011 年提出,当时他在雅虎工作,为 Yahoo Mail 编写 CSS。

(1)规则

1、Categorizing CSS Rules(CSS 分类规则)

它将 CSS 分为5个不同的类别:

Base 基本规范

例如 CSS Reset 和 CSS Normalize。

Layout 布局规范

例如左右分栏、栅格系统。

Module 模块

例如一个产品列表,一个导航条。可重用。

State 状态规范

例如选中状态。

Theme 样式规范

2、Naming Rules(命名规则)

为类名添加前缀

Base 不需要前缀。而且是用标签而不是 class 和 ID。

例子:


  
  ...

(2)实例

在线 demo:https://codepen.io/savemuse/pen/gWVpvd

4、 Atomic CSS

Atomic CSS 也是雅虎提出的,可以从字面意思理解成原子 CSS

(1)示例

会有专门的 Atomic css 工具,帮助将上面 html 中的 class name 解析成正常的 css。(略)

(2)利弊

好处:将 CSS style 最小元件化,重用性最大化。

坏处:这根本就是在写 inline-style,只是我们用 class name 的方式來表示而已。

(3)总结

这种做法真的很激进。我暂时无法接受。

三、总结

抛开激进的Atomic,我对剩下的 OOCSS / BEM / SMACSS 有如下建议:

他们各自的思想有互补也有冲突,在实际开发中可以有取舍的使用

他们都可以结合 CSS 预处理器(如 less/sass )获得更好的效率

把上文分别介绍他们的好处列举在一起对比汇总,发现他们解决的核心问题就是:模块化
 

怎么在CSS中利用methodologies实现模块化

上述就是小编为大家分享的怎么在CSS中利用methodologies实现模块化了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注创新互联行业资讯频道。


名称栏目:怎么在CSS中利用methodologies实现模块化
链接地址:http://csdahua.cn/article/gjgeds.html
扫二维码与项目经理沟通

我们在微信上24小时期待你的声音

解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流

其他资讯