开发一个自己的 CSS 框架(三)

这一期不涉及框架更新,我们来简单介绍一个各种 CSS 写法。各种写法大致就是相互借鉴吧。

BEM

<ul class="menu">
    <li class="menu__item menu__item--selected"></li>
    <li class="menu__item"></li>
    <li class="menu__item"></li>
</ul>

menu 是 block 区块,而 item 是 element 元素,selected 是 modify 状态。相比较普通的而言,它没有优先级问题。

由于我们的纯 css 面向的是前端页面,优先级问题出现的还是比较少。一些富交互的 UI 框架大多使用这种类型。

OOCSS

大概像这样,跟辅助类比较像。

<div class="size1of4 bgBlue solidGray mts mlm mrm mbm"></div>

或者这样,这里加了一个命名空间 s 。跟 BEM 结合起来画风像这样。

.btn
.btn--small
.btn--red
.btn--blue
.btn--large

SMACSS

  • Base Rules (全局重置样式等)

  • Layout Rules 用l-或layout-这样的前缀,例如:.l-header、.l-sidebar。见过京东的采用这种简写,不过他会加一个注释,注明 layout 的缩写是 l。

  • Module Rules 用模块本身的命名,例如图文排列的.media、.media-image。

  • State Rules 用 is- 前缀,例如:.is-active、.is-hidden。比如 bulma 里面的一些修饰符,其实都是 is 或者 has 开头的。

  • Theme Rules 如果作为单独 class,用 theme- 前缀,例如 .theme-a-background、.theme-a-shadow。

.layout-header {}
.layout-container {}
.layout-sidebar {}
.layout-content {}
.layout-footer {}

也可以自定义

.todolist{}
.todolist-title{}
.todolist-image{}
.todolist-article{}

在 Vue 中的单个文件,其实就是模块,加上了 scoped 之后,都会有自己的模块 ID,其实就相当于加上了这样的前缀,而 react 也有一种叫做 CSS-BLOCKS 的东西。

CSS-BLOCKS

好像只能用在 react 里面,在官网没看到单独使用的例子,它编译出来的 class 名称会自动缩短。笔者 react 经验不多,所以也就没有真正是实践与深究这个框架。

通过 scope 约束作用域,通过 state 创建状态,比如激活状态,不可用状态等等。

不过他也有一些缺点或者说强约定,一些伪类不支持嵌套,以及属性选择器,id 选择器等等。

:scope {}
:scope[state|enabled] { }

.sub-element { }
// 任意值时,包括无值
.sub-element[state|color] { }
// 特殊值
.sub-element[state|color="red"] { }
.sub-element[state|color="blue"] { }
.sub-element[state|color="yellow"] { }

当映射到 jsx 上面时候,要这样使用。

:scope {  }
:scope[state|enabled] {  }
.button {  }
.icon {  }
.icon[state|inverse] {  }
<section state:enabled={{isEnabled}}>
  <button class="button">
    <div class="icon" state:inverse={{isInverse}}></div>
    {{value}}
  </button>
</section>

AtomicCSS

这个像函数调用,在 class 上面有些异类,邪教的感觉。不过在 js 里面倒是感觉正常些,被 Block-CSS 接纳。

<div class="BfcHack M(10px)">
    <a class="Fl(start) Mend(10px)">
        <img >
    </a>
</div>
.Fl\(start\) {
 float: left;
}
.M\(10px\) {
 margin: 10px;
}

ITCSS

用这个规则写 sass 嵌套会少一些。

设置

可被覆盖的配置项

  • 基本 (重置样式)
  • 颜色 (基本色调)
  • 排版 (行高,字体,字号)
  • 动画 (animation 帧)

工具

utils 函数

  • 函数 (@function 定义的)
  • 占位符 (sass 中 % 开头的,选择器的复用)
  • 混合宏 (mixin,sass 中 = 开头的)
  • 媒体查询

sass 混合宏

=from($device)
  @media screen and (min-width: $device)
    @content

sass 函数

@function powerNumber($number, $exp)
  $value: 1
  @if $exp > 0
    @for $i from 1 through $exp
      $value: $value * $number
  @else if $exp < 0
    @for $i from 1 through -$exp
      $value: $value / $number
  @return $value

供应商

vendor ,会 php 的应该对这个文件很熟悉,noder 可以理解为 node_modules。即通过 npm 安装的第三方工具包,reset.css 等。

对象

通产有一个命名空间(o-), Object 的缩写,所有页面都是用的对象类,比如容器,布局等。

  • o-page 包裹一下,避免想要操作整个页面需要选取 html
  • o-gird 网格布局
  • o-container 某个组件外部容器类,固定最大宽度,可伸缩
  • o-main 主体内容区域,跟 main 标签类似
  • o-content 文本内容区域,或内部容器。

元素

element, 以 e- 开头

组件

component,以 c- 开头

作用域

scope 以 s- 开头

模式

pattern 以 p- 开头,组件的组合体,不可复用的结构。

其他命名空间

is- 和 js-,is- 表状态,js 表示 javascript 绑定的事件。

说了那么多,你喜欢哪一个呢?本 css 框架,不涉及任何 css 书写规范,这些更多应用于实际页面开发,而不是框架开发,为所有组件都添加一个 c- 命名空间,感觉也很奇怪.

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 156,907评论 4 360
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 66,546评论 1 289
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 106,705评论 0 238
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,624评论 0 203
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 51,940评论 3 285
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,371评论 1 210
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,672评论 2 310
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,396评论 0 195
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,069评论 1 238
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,350评论 2 242
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 31,876评论 1 256
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,243评论 2 251
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 32,847评论 3 231
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,004评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,755评论 0 192
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,378评论 2 269
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,266评论 2 259

推荐阅读更多精彩内容

  • 1、通过CocoaPods安装项目名称项目信息 AFNetworking网络请求组件 FMDB本地数据库组件 SD...
    X先生_未知数的X阅读 15,934评论 3 118
  • 觉得自己关注心理是从喜欢买《心理》这本杂志开始的,喜欢里面的剖析,也喜欢自我反省,当时最害怕的是自己会成为妈妈那样...
    转运之轮阅读 196评论 0 0
  • 一切英豪联盟玩家触摸的第一个adc英豪肯定是寒冰射手,从你一开始登录英豪联盟,菜鸟教育引荐的英豪之一,可是你真实的...
    LOL小雪琪阅读 949评论 1 2
  • 谢谢你,喜欢我 谢谢你,让我成长 对不起,因为我而带给了你痛苦 抓紧你,是因为爱你 放开你,更是因为心疼你 如果用...
    Tommy教练阅读 153评论 0 0