返回顶部
首页 > 资讯 > 前端开发 > node.js >CSS编程的OOCSS和SMACSS设计模式介绍
  • 192
分享到

CSS编程的OOCSS和SMACSS设计模式介绍

2024-04-02 19:04:59 192人浏览 安东尼
摘要

本篇内容主要讲解“CSS编程的OOCSS和SMacSS设计模式介绍”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“CSS编程的OOCSS和SMACSS设计模式介绍

本篇内容主要讲解“CSS编程的OOCSS和SMacSS设计模式介绍”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“CSS编程的OOCSS和SMACSS设计模式介绍”吧!

OOCSS

OOCSS 不是什么新技术,只是一种撰写 CSS 的设计模式,或者可以说是一种「道德规范」,大致上我觉得重点只有两个:

  1.     减少对 html 结构的依赖
        增加 CSS class 重复性的使用

减少对 HTML 结构的依赖
 

CSS Code复制内容到剪贴板

  1. <nav class="nav--main">   

  2.   <ul>   

  3.     <li><a>.........</a></li>   

  4.     <li><a>.........</a></li>   

  5.     <li><a>.........</a></li>   

  6.   </ul>   

  7. </nav>     

一般的导航栏写法,结构应该会像上面的 HTML 范例一样,如果要对那些 <a> 标签定义样式,CSS 的写法可能写成.nav--main ul li a {},这种写法先不管效能上的问题,可以看出来过度地依赖元素标签的结构,有可能之后 HTML 结构改变,这个 CSS 就必须跟著重构,造成维护上多余的成本。

若从这个例子来考量,原则上 <a> 都一定会接在 <li> 标签的后面,一个 <li> 只会有一个 <a>,通常不会独立存在,那就可以写成 .nav--main a {},会是比较好的写法,甚至是直接给 <a> 加上 class nav--main_item。后者是 OOCSS 所提倡的用法。

这样的写法,一来效能理论上比较好(我没办法验证),二来层次比较单纯。
增加 CSS class 的重复使用

在 OOCSS 的观念中,强调重复使用 class,而应该避免使用 id 作为 CSS 的选择器。这种想法就是像
OOP
尽量抽离重复的程式码,例如以下这个例子,这是两种按钮的 CSS 样式属性:
 

CSS Code复制内容到剪贴板

  1. .button {   

  2.   display: inline-block;   

  3.   padding: 6px 12px;   

  4.   color: hsla(0, 100%, 100%, 1);   

  5.   &.button-default { background: hsla(180, 1%, 28%, 1); }   

  6.   &.button-primary { background: hsla(208, 56%, 53%, 1); }   

  7. }   

上面的 CSS 将两种不同样式的 button,抽离出重复的部份,并且定义在同个 class
上。因此,要使用这样的样式,HTML 的写法可能长这个样子:
 

CSS Code复制内容到剪贴板

  1. <a class="button button-default">   

  2. <a class="button button-primary">  

先用 button 宣告此为一个按钮的样式,再用 button-default 或 button-primary 作为按钮底色的区别。这么做可以维护成本变得比较低,例如:想要改网站上所有按钮的大小,就只要修改 .button 的 padding 而已。
SMACSS

我对 SMACSS 的理解还不是很深入,或许把 Scalable and Modular Architecture for CSS 看完后会有更深一曾的理解。目前对 SMACSS 的概念仅限于它对 CSS 不同的业务逻辑所做的划分方式:

但我认为原本的设计不是很妥当,因此我自己做了一些改良:
Base

Base 就是设定标签元素的预设值,例如浏览器的 reset 可以写在这里,如果用的是 Compass,只要 @include global-reset 即可。这里只会对标签元素本身做设定,不会出现任何 class 或
id,但是可以有属性选择器或是伪类:
 

CSS Code复制内容到剪贴板

  1. html {}   

  2. input[type=text] {}   

  3. a:hover {}   

Layout     

Layout 是指整个网站的「大架构」的外观,而非 .button 这种小元件的 class。网站通常会有一些主要的大区块,可能是 header 或 footer,Layout 就是用来定义这些「大架构」的 CSS。如果有做 Responsive WEB Design 或是用 Grid System,也是把规则写在 Layout 这里。

以下这是个范例:
 

CSS Code复制内容到剪贴板

  1. #header { margin: 30px 0; }   

  2. #articles-wrapper { ......; }   

  3. .sidebar {   

  4.   &.sidebar--rightright { ......; }   

  5.   &.sidebar-left { ......; }   

  6. }  

通常只有一个选择器,一个 id、或一个 class。
Module

原本的 SMACSS 对 Module 的设计我觉得不是很好,所以我硬是将 Module
拆分出一个 Partial。

这里的 Module 顾名思义,就是可以在其他地方被重复使用,如果要找更明确的例子,我想就像 Twitter Bootstrap 的Components
一样,或者像前面 OOCSS 所举例的 .button 这种会被重复使用的元件模组。

模组不需要用任何的 prefix,因为 Module 就是设计来可以重复应用在不同的 page 上。
Partial

Partial 跟 Latout 不同,也跟 Module 不同,他比 Layout 的范围小,可能是
header 底下的某个子元素。他不像 Module,他是特定单一领域下特别的设定。

CSS Code复制内容到剪贴板

  1. .nav--main {   

  2.   a { ......; }   

  3. }  

通常会将 Partial 的名称加在子 class 作为 prefix,例如 .nav--main 底下的
.nav--main_item。至于为什么要用这么奇怪的命名方式?这等等在 CSS 规范部分会说明介绍。
State

State 负责定义元素不同的状态下,所呈现的样式。但是并非指一个元素的 :hover 或 :active 下的状态。举例来说,一个导航栏分页,目前所在页面的分页需要加上 .active
的属性表示目前位置是在这个分页,HTML 会长这样:

CSS Code复制内容到剪贴板

  1. <nav class="nav--main">   

  2.   <ul>   

  3.     <li><a>.........</a></li>   

  4.     <li class="active"><a>.........</a></li>   

  5.     <li><a>.........</a></li>   

  6.   </ul>   

  7. </nav>  

因此可以替 .nav--main 增加 .active 这样的子 class:

CSS Code复制内容到剪贴板

  1. .nav--main {   

  2.   // others&hellip;;   

  3.   .active {   

  4.     background: darken($background-color, 16%);   

  5.   }   

  6. }  

有时候为了让阅读更贴近语义,会用比较友善的命名方式,以此段的范例来说,.is-active 就比 .active 来得好读。
Theme

Theme 是画面上所有「主视觉」的定义,例如 border-color、background-image 或是 font-family 等相关的 Typography 设定。为什么说是「主视觉」?因为有些元件模组仍然是留在 Module 去定义,Theme 就像 Layout 一样负责「大架构」上的视觉样式。

编者注 感谢 Only1Word 指出,theme 在 SMACSS 中更类似皮肤。
CSS 规范

这里整理的是我觉得一定要知道的,其他还有很多规范可以转到文末的参考资源连结,那篇文章有介绍更多的细节。
BEM

BEM 即 Block、Element、Modifier 的缩写,这是一种 class 的命名技巧。如果整个 project 只有自己一个人做,那当然是不太可能出现 class 重复的问题,但是如果同时多个 F2E 一起写同个部分的 CSS,就很容易出现共用 class 的问题,因此有了 BEM 这样的命名技巧。

将 Block 区块作为起始开头,像前面 SMACSS 介绍的 Partial 就可以拿来作为 Block 的 prefix 名称;Element 则是 Block 下的元素;Modifier 则是这个元素的属性。

不同 Block 和 Element 用 __ 两个底线区隔开来,不同的 Modifier 则用 -- 两个 dash 区隔。至于 - 一个 dash 则表示这个 class 不依赖任何 Block 或 Element,是个独立的存在,例如:.page-container 或 .article-wrapper。

这里有个范例:

CSS Code复制内容到剪贴板

  1. .sidebar {   

  2.   .sidebar--left__section {   

  3.     .sidebar--left__section--header {}   

  4.     .sidebar--left__section--footer {}   

  5.   }   

  6. }   

Javascript Hook

透过 CSS class 来作为 javascript 选取 DOM 节点的方式,就是 Javascript Hook。用 Jquery 可以常常看到这样的写法:$('.nav--main a'),可是当 CSS 跟 Javascript 搅在一起反而造成两边维护上的不便,当改了 CSS 时 Javascript 也要跟著改。

所以用 HTML 的属性去选取 DOM 节点会更好,如果非要用 CSS 的 class 那也可以多写一个 js- 的 prefix,以表示这个节点有被 Javascript 使用,例如:

CSS Code复制内容到剪贴板

  1. <li class="nav--main__item  js-nav--main__item"><a>.........</a></li>   

  2. <li class="nav--main__item  js-nav--main__item"><a>.........</a></li>   

  3. <li class="nav--main__item  js-nav--main__item"><a>.........</a></li>  

PS. HTML 里两个 class 之间用两个空格,会比一个空格看起来好阅读。
合理的选择器

    class 无所谓是否语意化的问题;你应该关注它们是否合理,不要刻意强调 class
    名称要符合语意,而要注重使用的合理性与未来性。

有时候为了表示更明确,在使用 CSS 的选择器时,要表示某的 class 是搭配某个标签元素使用,会写成这样:

CSS Code复制内容到剪贴板

  1. ol.breadcrumb{}   

  2. p.intro{}   

  3. ul.image-thumbs{}  

但是上面这个写法效能不是很好,同样的目的但可以减少多余的修饰,试试改用下面这种写法,将标签名称用注解标示起来,维护上有相同的效果,但是浏览器处理的速度会比较快:
 

CSS Code复制内容到剪贴板

  1. .breadcrumb{}   

  2. .intro{}   

  3. .image-thumbs{}  

到此,相信大家对“CSS编程的OOCSS和SMACSS设计模式介绍”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

--结束END--

本文标题: CSS编程的OOCSS和SMACSS设计模式介绍

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

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

猜你喜欢
  • CSS编程的OOCSS和SMACSS设计模式介绍
    本篇内容主要讲解“CSS编程的OOCSS和SMACSS设计模式介绍”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“CSS编程的OOCSS和SMACSS设计模式介绍...
    99+
    2024-04-02
  • CSS的OOCSS和SMACSS设计模式是什么
    这篇文章主要介绍“CSS的OOCSS和SMACSS设计模式是什么”,在日常操作中,相信很多人在CSS的OOCSS和SMACSS设计模式是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望...
    99+
    2024-04-02
  • 设计模式和反模式简单介绍
    作为一个资深开发人员,大家都应该听说过设计模式(design pattern),但是不是所有的人都听说过反模式(anti-pattern)。今天我们就来谈谈后者,何为反模式。谈反模式之前当然先要谈谈何为设计模式,因为两者是紧密联系在一起的。...
    99+
    2023-06-03
  • CSS中的OOCSS编程方式是怎样的
    CSS中的OOCSS编程方式是怎样的,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。OOCSS即面向对象的CSS,这里对象指的是页面中的元素...
    99+
    2024-04-02
  • VB.NET窗体编程模式的介绍
    这篇文章主要讲解了“VB.NET窗体编程模式的介绍”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“VB.NET窗体编程模式的介绍”吧!VB.NET窗体编程模式到现在为止,我们讨论的只是如何创建...
    99+
    2023-06-17
  • C++设计模式中的工厂模式详细介绍
    目录1. 简单工厂模式2. 工厂方法模式3. 抽象工厂模式1. 简单工厂模式 简单工厂模式(Simple Factory Pattern): 是指定义一个工厂类,工厂类中实现一个方法...
    99+
    2024-04-02
  • java设计模式中的单例模式简单介绍
    这篇文章主要介绍“java设计模式中的单例模式简单介绍”,在日常操作中,相信很多人在java设计模式中的单例模式简单介绍问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”java设计模式中的单例模式简单介绍”的疑...
    99+
    2023-06-02
  • C语言设计模式之命令模式介绍
    目录介绍:传统方式:命令模式:总结介绍: ​ 命令模式是一种行为模式,它可以使代码解耦,便于维护; 假设我们现在要设计一个命令解析的模块: 传统方式: void func1(void...
    99+
    2024-04-02
  • Java的24种设计模式详细介绍
    这篇文章主要介绍“Java的24种设计模式详细介绍”,在日常操作中,相信很多人在Java的24种设计模式详细介绍问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java的24种设计模式详细介绍”的疑惑有所帮助!...
    99+
    2023-06-16
  • .NET设计模式之UML类图介绍
    目录一、概述1、类名2、属性3、方法4、接口二、关系各种关系的强弱顺序:1. 依赖(Dependency)2. 关联(Association)3. 聚合(Aggregation)4....
    99+
    2024-04-02
  • 简介Python设计模式中的代理模式与模板方法模式编程
    代理模式 Proxy模式是一种常用的设计模式,它主要用来通过一个对象(比如B)给一个对象(比如A) 提供'代理'的方式方式访问。比如一个对象不方便直接引用,代理就在这个对象和访问者之间做了中介 python...
    99+
    2022-06-04
    模式 模板 简介
  • Spring中常用的9种设计模式介绍
    这篇文章主要介绍“Spring中常用的9种设计模式介绍”,在日常操作中,相信很多人在Spring中常用的9种设计模式介绍问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Spring中常用的9种设计模式介绍”的疑...
    99+
    2023-06-02
  • C#面向对象的23种设计模式介绍
    目录一、设计模式概述二、面向对象23种设计模式创建型模式结构型模式行为型模式三、设计模式六大原则详细解析四、源码仓库一、设计模式概述 设计模式,是一套被反复使用、多数人知晓的、经过分...
    99+
    2024-04-02
  • JavaScript设计模式中的桥接和中介者模式
    目录一、桥接设计模式桥接设计模式在工作中的使用二、JavaScript中介者模式生活中的中介者中介者设计模式案例业务中的中介者一、桥接设计模式 桥接设计模式是一种偏向于组合的设计模式...
    99+
    2024-04-02
  • Java结构性设计模式中的装饰器模式介绍使用
    目录装饰器模式概述实现原理主要角色应用场景优缺点装饰器模式的基本使用创建抽象组件具体组件抽象装饰器具体装饰器客户端调用装饰器模式 概述 装饰器模式(Decorator Pattern...
    99+
    2024-04-02
  • Go语言中常见的编程范式和设计模式
    Go语言作为一门现代化的、高效的编程语言,拥有丰富的编程范式和设计模式可以帮助开发者编写高质量、可维护的代码。本文将介绍Go语言中常见的编程范式和设计模式,并提供具体的代码示例。 1....
    99+
    2024-03-04
    接口 并发 单例 go语言
  • .NET异步编程模式的三种类型介绍
    一、引言 .NET中很多的类、接口在设计的时候都考虑了多线程问题,简化了多线程程序的开发,不用自己去写WaitHandler等这些底层的代码,由于历史的发展,这些类的接口设计有着三种...
    99+
    2024-04-02
  • JDK中的设计模式简介
    这篇文章主要讲解了“JDK中的设计模式简介”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JDK中的设计模式简介”吧!设计模式是什么(1)反复出现问题的解决方案(2)增强软件的灵活性(3)适应...
    99+
    2023-06-02
  • PHP 函数式编程与设计模式
    函数式编程采用不可变值和函数应用,可提高代码稳定性。结合设计模式,它创造了高效且易于维护的应用程序。例如,策略模式使用映射函数来选择算法,我们演示了使用冒泡排序和快速排序策略对数组进行排...
    99+
    2024-05-06
    php 函数式编程 冒泡排序
  • JavaScript闭包以及几种设计模式的详细介绍
    这篇文章主要介绍“JavaScript闭包以及几种设计模式的详细介绍”,在日常操作中,相信很多人在JavaScript闭包以及几种设计模式的详细介绍问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作