返回顶部
首页 > 资讯 > 精选 >怎么在CSS中利用methodologies实现模块化
  • 669
分享到

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

2023-06-08 05:06:07 669人浏览 独家记忆
摘要

这期内容当中小编将会给大家带来有关怎么在CSS中利用methodologies实现模块化,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。一、什么是 CSS methodologiesCSS methodol

这期内容当中小编将会给大家带来有关怎么在CSS中利用methodologies实现模块化,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

一、什么是 CSS methodologies

CSS methodologies,可以理解成 设计模式,也可以理解成 css 规范,市面使用情况如下图:

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

二、常见的 CSS methodologies

1、OOCSS

面向对象的 CSS(Object-Oriented CSS,简称 OOCSS ),由 Nicole Sullivan 于 2008 年提出,这基于她在雅虎的工作。

(1)规则

1、不要使用 ID 用 Class

直接使用class来设定样式,这样写不只是可以增加语义,同時也降低css对html的依赖。

2、结构和样式分离

虽然早期 html 和 css 实现了结构和样式的分离,但 css 内部同样存在两种类型的样式:

  • 结构样式(例如长宽、距离)

  • 皮肤样式(例如颜色、阴影)

所以 OOCSS 建议把这两种样式拆开。

比如有三种按钮,白色的/绿色的/红色的,可分别定义为:

class="btn btn-default"class="btn btn-green"class="btn btn-red"

如果你真的有很多个具有紫色按钮,则可以创建一个单独的紫色按钮类。这样可以大大减少CSS代码的数量。

3、容器和内容分离

内容绝不应该限制于特定的容器,为了重用,得分离开。

# 错误写法.header .action {}.header .action .login {}.header .action .reGISter {}# 正确写法.header{}.action{}.login {}.register {}

继承选择符是有用的,它可以减少因相同命名引发的样式冲突(常发生于多人协作开发)。但是,我们不应过度使用。

(2)利弊

好处:

  • 模块化,可重用

  • 减少代码重复

  • 提高可拓展性、可维护性、可读性

缺点:

  • 虽减少了深层的嵌套选择器,但是多了更多的类

  • 如果代码中没有大量重复的视觉模式,比如一些小项目,则应用OOCSS可能不切实际

(3)实例

Bootstrap 就是用的 OOCSS。

例如:

html

 <div class='header'>        <ul class='menu'>             <li class='menu-item active'>1</li>            <li class='menu-item'>2</li>            <li class='menu-item'>3</li>        </ul>        <div class="action">            <button class="btn btn-login">login</button>            <button class="btn btn-register">register</button>        </div>    </div>

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:

<div class='header'>        <ul class='header__menu'>             <li class='header__menu-item--active'>1</li>            <li class='header__menu-item'>2</li>            <li class='header__menu-item'>3</li>        </ul>        <div class="header__action">            <button class="header__btn--login">login</button>            <button class="header__btn--register">register</button>        </div>    </div>

demo - less:

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

2、避免嵌套

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

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

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

(3)利弊

好处:

  • 层级关系一目了然,具有可读性

  • 不需要依靠层级选择器来限定约束作用域,可避免跨组件的样式污染。

缺点:

  • 命名方式长而难看,书写不便(可以通过 less/sass 来简化书写)

  • 在较小的组件中,BEM 格式可能显得鸡肋。但对于公共的、全局性的模块样式定义,还是推荐使用 BEM 格式。(尤其对外发布的公共组件)

其他:

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

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

(4)实践

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

3、SMACSS

SMacSSScalable & 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。

  • l- 用作 Layout 的前缀:l-inline

  • m- 用作 Module 的前缀:m-callout。但也可以不用前缀。

  • is- 用作 State 的前缀:is-collapsed

  • Theme 一般会新建个 theme.css,用之前存在的类名。如果想用单独的类名,可用 theme- 前缀。

例子:

<div class="l-box m-profile m-profile--is-pro-user">  <img class="m-avatar m-profile__image" />  <p class="m-profile__bio">...</p></div>

(2)实例

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

4、 Atomic CSS

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

(1)示例

<div className="P(10px) M(20%) Pos(f) Start(50%) BGC(#fff)" />

会有专门的 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实现模块化了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注编程网精选频道。

--结束END--

本文标题: 怎么在CSS中利用methodologies实现模块化

本文链接: https://lsjlt.com/news/252091.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 怎么在CSS中利用methodologies实现模块化
    这期内容当中小编将会给大家带来有关怎么在CSS中利用methodologies实现模块化,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。一、什么是 CSS methodologiesCSS methodol...
    99+
    2023-06-08
  • css中如何实现模块化
    css中如何实现模块化?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。oocss面对对象的规则,主要的原则是两种:分离结构和外观,分离容器和内容。名词解释分离结构和外观:增加...
    99+
    2023-06-08
  • 怎么在python中利用第三方模块实现连接
    怎么在python中利用第三方模块实现连接?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。python的数据类型有哪些python的数据类型:1. 数字类型,包括int(整型)、...
    99+
    2023-06-14
  • python3中利用serial模块实现
       python上位机向单片机发送字符,单片机如果收到的字符为‘1’,则点亮灯1,如果收到的字符为‘2’,则点亮灯2;单片机若接受到字符,读取字符后,向python上位机发送字符(1->X,2->T),若python上位机...
    99+
    2023-01-31
    模块 serial
  • 怎么在Matplotlib中利用animation模块实现一个动态图
    本篇文章为大家展示了怎么在Matplotlib中利用animation模块实现一个动态图,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。matplotlib 画图功能非常强大,目前也只能根据官网 提供...
    99+
    2023-06-06
  • 怎么在HTML页面中实现模块化加载
    这篇文章给大家介绍怎么在HTML页面中实现模块化加载,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。公共模板定义思考后发现可以把公共模板抽取到一个HTML文件中(文件名就暂定PublicModule.html),如下:&...
    99+
    2023-06-09
  • 怎么在Python中利用 Asyncio模块实现一个生产消费者模型
    本文章向大家介绍怎么在Python中利用 Asyncio模块实现一个生产消费者模型的基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。Python主要用来做什么Python主要应用于:1、Web开发;2、数...
    99+
    2023-06-06
  • MySQL中怎么利用pam_mysql模块实现vsftpd虚拟用户
    MySQL中怎么利用pam_mysql模块实现vsftpd虚拟用户,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。一、实验环境的...
    99+
    2024-04-02
  • 怎么在CocosCreator中模块化脚本
    怎么在CocosCreator中模块化脚本?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。Cocos Creator模块化脚本Cocos Creator 允许你将...
    99+
    2023-06-14
  • Python利用第三方模块实现压缩css文件
    目录csscompressor 库使用cssmin 库的用法rcssmin 库的用法总结csscompressor 库使用 在 Python 中可以使用多种方法来压缩 CSS 文件。...
    99+
    2023-01-28
    Python压缩css文件 Python压缩css Python压缩文件
  • css中Grid模块怎么使用
    本篇内容介绍了“css中Grid模块怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!模块说明为了创建一个有行和列的布局,Grid模块增...
    99+
    2023-06-30
  • 怎么在python中利用random模块求随机数
    怎么在python中利用random模块求随机数?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。python主要应用领域有哪些1、云计算,典型应用OpenStac...
    99+
    2023-06-14
  • Python怎么利用re模块实现简易分词
    本文小编为大家详细介绍“Python怎么利用re模块实现简易分词”,内容详细,步骤清晰,细节处理妥当,希望这篇“Python怎么利用re模块实现简易分词”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一个简单的to...
    99+
    2023-06-30
  • 怎么在python中模块化日志库
    怎么在python中模块化日志库?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。Python的优点有哪些1、简单易用,与C/C++、Java、C# 等传统语言相比...
    99+
    2023-06-14
  • Python利用pangu模块实现文本格式化小工具
    其实使用pangu做文本格式标准化的业务代码在之前就实现了,主要能够将中文文本文档中的文字、标点符号等进行标准化。 但是为了方便起来我们这里使用了Qt5将其做成了一个可以操作的页面应...
    99+
    2024-04-02
  • 使用pandas模块怎么实现数据标准化
    本篇文章给大家分享的是有关使用pandas模块怎么实现数据标准化,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。如下所示:3σ 原则(u-3*σ ,u+3*σ )离差标准化(x-...
    99+
    2023-06-15
  • os模块与fnmatch模块怎么在python中使用
    本篇文章为大家展示了 os模块与fnmatch模块怎么在python中使用,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。python可以做什么Python是一种编程语言,内置了许多有效的工具,Pyt...
    99+
    2023-06-08
  • JavaScript利用crypto模块实现加解密
    目录一、 散列(哈希)算法1、如何获取所有的散列算法2、使用方法3、散列算法例子4、多次update二、HMac 算法三、对称AES加密1、如何加密2、如何解密一、 散列(...
    99+
    2023-02-10
    JavaScript crypto加解密 JavaScript crypto JavaScript 加解密
  • 怎么在python中使用selenium模块实现自动登录
    怎么在python中使用selenium模块实现自动登录?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。python可以做什么Python是一种编程语言,内置了许多有效的工具...
    99+
    2023-06-14
  • flask中的蓝图实现模块化的应用
        Blueprint     蓝图的基本设想是当它们注册到应用上时,它们记录将会被执行的操作。 当分派请求和生成从一个端点到另一个的 URL 时,Flask 会关联蓝图中的视图函数。     简单来说,Blueprint 是一个存储...
    99+
    2023-01-30
    蓝图 flask
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作