OOCSS —— 面向对象CSS

5.CSS团队精神:CSS最佳团队开发

  在本文中,你将学习书写CSS的最佳实践来帮助你避免不一致和冗余;实际上,这样制定标准,简化了团队开发的工作。

  1)结构化

    (根据不同内容分区块,加注释)

  2)越多的CSS就需要越多的组织

    (加二级注释)

  3)自由格式化

    另一些人使用特殊字符如‘=’,作为搜索字符的标记:

  4)交流注释用法

  5)什么时间,谁做了什么

    (文件头部增加文件创建和更新的摘要注释)

  6)颜色值

    COLORS: Green #b3d88c | Blue #0075b2 | Light Gray #eee | Dark Gray #9b9e9e | Orange #f26522 | Teal #00a99d | Yellow #fbc112

    (提前定好,方便维护)

  7)开发和调试

    (将有问题或疑惑的地方注释出来,有时间时找同事一起解决)

  8)样式重置

    Eric Meyer的重置文档,去掉用不到的标签。

    不过,我应该澄清一下,css重置并不适用于所有人。你有很多不使用他的理由,这由你决定。如果你要重置样式,要保持你的重置样式表尽量干净和特殊。

  9)命名约定

    不仅仅是上下文,有语意的命名还可以节约时间。考虑到一个公司品牌的频繁更换,如果你开发的css使用表现的类名而不是语义化的类名和id名,那么在寻找、维护css时,你将比预期花费更多的时间。

  10)类名滥用

    由此产生的css本身和他造成的冗余并不可怕,可怕的是他造成的困惑。作为一个设计师看到了这个form类,可能猜想是不是其他样式表里也定义了叫form的类名,然后去查找根本不存在的样式,这就是我时间浪费的原因。

  11)类名不等于特异性

    如果你的元素定义样式不需要类名,那就不要用。用的太多类名,不仅使你的结构和css很臃肿,也失去了他们在css 中的意义。

  12)多类

    虽然我不提倡使用不必要,多余的类名,但是对于通过多类保持元素表现的共用

  13)分组选择器

  14)一行还是多行书写?

    一行

  15)需要按照字母排序吗?

    (结构排序或字母顺序排序,你想用哪个用哪个)

  16)使用简写

  17)0值

    没必要给他指定单位

  18)颜色模式

  19)(。。。以下省略)

6.开始编写CSS

  (这篇写的比较NB,直接看原文好)

  1)CSS预处理器

    SASS

  2)BEM

    块(Block)、元素(Element)和修改器(Modifier)

.site-header { ... } /* block */
.site-header__logo { ... } /* element */
.site-header__logo--xmas { ... } /* modifier */
.site-header__navigation { ... } /* element */

  3)OOCSS

    面向对象CSS

  4)SMACSS

    SMACSS代表可伸缩的和是模块化的CSS结构体系

    • 基本(base):用于一个简单的选择器的基本样式,如clearfix
    • d布局(Layout):定义网格
    • 模块(Module):一群元素相结合在一起形成的一个模块,比如说headersidebar
    • 状态(State):元素的不同状态。如隐藏、按住,扩大等规则定义给对象
    • 主题(Them):更多的样式

  5)Atomic Design

  6)OrganicCSS

    虽说没看明白啥意思,但发现一个比较吊的mixin

@mixin login-box {
@include atoms((
block,
font-size-20,
margin-top-23,
bold
));
}

    可以写一写。有个库,地址:http://krasimir.github.io/organic-css/

7.OOCSS + Sass

  先上一个PPT:http://takazudo.github.io/presentation-oocss-sass/

  用@extend + %占位符来实现OOCSS,多写写什么都明白了。

  而且OOCSS可以用于页面布局,但要注释明白,逻辑明确。

8.崇拜CSS

  其实就是让你用sass来写OOCSS,而不是用css直接写(这样会造成标签过长,失去语义化)。

9.使用Sass来写OOCSS

  和7一样。

  

最后,加一篇SMACSS的:

10.如何使用Sass和SMACSS维护CSS

  写的很好,结合实际项目,可以用来参考。

.my-module {
background-color: maroon;
position: relative; > a {
color: aqua;
}
}
.my-module--important {
@extend .my-module;
border: 3px solid fuchsia;
}
.my-module--is-active {
background-color:red;
}
.my-module__close-button {
position: absolute;
right:;
top:;
}

  分文件:

    modules/_my_module.scss

    modules/_child_component.scss

    modules/_grandchild-component.scss

  Configuration(配置)

  Mixins(混合)

  Grid(网格)

  我们不打算从我们编译的CSS中删除每一个重复点。我们想要开发尽可能的容易,而又不影响性能。到目前为止用mixins模块代替@extend,这样并不会增加原始文件大小。

OOCSS学习(二)的更多相关文章

  1. emberjs学习二(ember-data和localstorage_adapter)

    emberjs学习二(ember-data和localstorage_adapter) 准备工作 首先我们加入ember-data和ember-localstorage-adapter两个依赖项,使用 ...

  2. ReactJS入门学习二

    ReactJS入门学习二 阅读目录 React的背景和基本原理 理解React.render() 什么是JSX? 为什么要使用JSX? JSX的语法 如何在JSX中如何使用事件 如何在JSX中如何使用 ...

  3. TweenMax动画库学习(二)

    目录            TweenMax动画库学习(一)            TweenMax动画库学习(二)            TweenMax动画库学习(三)            Tw ...

  4. Hbase深入学习(二) 安装hbase

    Hbase深入学习(二) 安装hbase This guidedescribes setup of a standalone hbase instance that uses the local fi ...

  5. Struts2框架学习(二) Action

    Struts2框架学习(二) Action Struts2框架中的Action类是一个单独的javabean对象.不像Struts1中还要去继承HttpServlet,耦合度减小了. 1,流程 拦截器 ...

  6. Python学习二:词典基础详解

    作者:NiceCui 本文谢绝转载,如需转载需征得作者本人同意,谢谢. 本文链接:http://www.cnblogs.com/NiceCui/p/7862377.html 邮箱:moyi@moyib ...

  7. Quartz学习--二 Hello Quartz! 和源码分析

    Quartz学习--二  Hello Quartz! 和源码分析 三.  Hello Quartz! 我会跟着 第一章 6.2 的图来 进行同步代码编写 简单入门示例: 创建一个新的java普通工程 ...

  8. SpringCloud学习(二):微服务入门实战项目搭建

    一.开始使用Spring Cloud实战微服务 1.SpringCloud是什么? 云计算的解决方案?不是 SpringCloud是一个在SpringBoot的基础上构建的一个快速构建分布式系统的工具 ...

  9. DjangoRestFramework学习二之序列化组件、视图组件 serializer modelserializer

      DjangoRestFramework学习二之序列化组件.视图组件   本节目录 一 序列化组件 二 视图组件 三 xxx 四 xxx 五 xxx 六 xxx 七 xxx 八 xxx 一 序列化组 ...

  10. SpringMVC入门学习(二)

    SpringMVC入门学习(二) ssm框架 springMVC  在上一篇博客中,我简单介绍了一下SpringMVC的环境配置,和简单的使用,今天我们将进一步的学习下Springmvc的操作. mo ...

随机推荐

  1. SRM 406(1-250pt, 1-500pt)

    DIV1 250pt 题意:有几家宠物店,vecort<int>A表示每家宠物店含有小狗占小狗总数的百分比.现在要做扇形统计图统计每家店的小狗百分比,如下图,问作出来的扇形统计图中最多含有 ...

  2. Jenkins 十二: 集成 selenium 测试

    我的selenium采用的是python版本. 其实 selenium java版本也类似. 1. 在jenkins里面新建selenium 测试项目. 源码管理采用 “Subversion”,输入 ...

  3. jSP的3种方式实现radio ,checkBox,select的默认选择值。

    jSP的3种方式实现radio ,checkBox,select的默认选择值.以radiao 为例:第一种方式:在jsp中使用java 脚本,这个方法最直接,不过脚本太多,不容易维护<%Stri ...

  4. linux 挂载ISO

    首先,将作为源的iso的挂载到系统上. 代码如下: mount -o loop /xxx/xxx.iso /mnt/iso/ 其中/mnt/iso是事先在本地建立的文件夹. 然后将文件iso.repo ...

  5. 如何提高Lucene构建索引的速度

    如何提高Lucene构建索引的速度 hans(汉斯) 2013-01-27 10:12 对于Lucene>=2.3:IndexWriter可以自行根据内存使用来释放缓存.调用writer.set ...

  6. Lucene中string docvalues使用utf-16的优化

    原来的string docvalues使用utf-8编码,载入时转码花费大量时间,我们把转码实现从new String(bytes, "UTF-8")改用lucene的bytesR ...

  7. CALayer的基本操作

     CALayer简介:   CALayer又称为层. 在每一个UIView内部都有一个Layer这样的属性. UIView之所以能够显示,就是因为它里面有这个一个层,才具有显示的功能. 我们通过操作C ...

  8. 《Android开发艺术探索》读书笔记 (6) 第6章 Android的Drawable

    本节和<Android群英传>中的第六章Android绘图机制与处理技巧有关系,建议先阅读该章的总结 第6章 Android的Drawable 6.1 Drawable简介 (1)Andr ...

  9. Android常用功能代码块(转)

    1.设置activity无标题,全屏 // 设置为无标题栏 requestWindowFeature(Window.FEATURE_NO_TITLE); // 设置为全屏模式 getWindow(). ...

  10. EventBus分析

    1. 功能介绍 1.1 EventBus EventBus 是一个 Android 事件发布/订阅框架,通过解耦发布者和订阅者简化 Android 事件传递,这里的事件可以理解为消息,本文中统一称为事 ...