`
agileai
  • 浏览: 53914 次
  • 性别: Icon_minigender_1
  • 来自: 沈阳
社区版块
存档分类
最新评论

CSS代码重构与优化之路

css 
阅读更多

作者:@狼狼的蓝胖子

网址:http://www.cnblogs.com/lrzw32/p/5100745.html

写CSS的同学们往往会体会到,随着项目规模的增加,项目中的CSS代码也会越来越多,如果没有及时对CSS代码进行维护,CSS代码不断会越来越多。CSS代码交错复杂,像一张庞大的蜘蛛网分布在网站的各个位置,你不知道修改这行代码会有什么影响,所以如果有修改或增加新功能时,开发人员往往不敢去删除旧的冗余的代码,而保险地增加新代码,最终的坏处就是项目中的CSS会越来越多,最终陷入无底洞。

CSS代码重构的目的

我们写CSS代码时,不仅仅只是完成页面设计的效果,还应该让CSS代码易于管理,维护。我们对CSS代码重构主要有两个目的:

  1. 提高代码性能

  2. 提高代码的可维护性

提高代码性能

提高CSS代码性能主要有两个点:

1、提高页面的加载性能

提高页面的加载性能,简单说就是减小CSS文件的大小,提高页面的加载速度,尽可以的利用http缓存

2、提高CSS代码性能

不同的CSS代码,浏览器对其解析的速度也是不一样的,如何提高浏览器解析CSS代码的速度也是我们要考虑的

提高代码的可维护性

提高CSS代码的可维护性主要是体现在下面几点:

1、可重用性

一般来说,一个项目的整体设计风格是一致的,页面中肯定有几个风格一致但有些许不同的模块,如何在尽可能多地重用CSS代码,尽可能少地增加新代码,这是CSS代码中非常重要的一点。如果CSS代码的重用性高,我们可能只需要写一些不一样的地方,对页面性能和可维护性、提高开发效率都有很大的帮助。

2、可扩展性

如果产品增加了某个功能,我们应该保证新增加的CSS代码不会影响到旧的CSS代码和页面,并且尽可能少地增加新代码而重用旧代码。

3、可修改性

如果某个模块产品经理觉得要修改样式,或者要删掉它,如果没有规划好相应的CSS代码,过了一段时间之后,开发人员可能已经不记得这段代码作用了几个地方,不敢修改或删除它,这样下去CSS代码也就越来越多,影响了页面的性能,还造成了代码的复杂度。

CSS代码重构的基本方法

前面说到了CSS代码重构的目的,现在我们来说说一些如何达到这些目的的一些基本方法,这些方法都是易于理解,容易实施的一些手段,大家平时可能也不知不觉地在使用它。

提高CSS性能的手段

首先说说如何提高CSS性能,根据页面的加载性能和CSS代码性能,主要总结有下面几点:

1、尽量将样式写在单独的css文件里面,在head元素中引用

有时候为了图方便或者快速搞定功能,我们可能会直接将样式写在页面的style标签或者直接内联在元素上,这样虽然简单方便,但是非常不利于日后的维护。将代码写成单独的css文件有几点好处:

  • 内容和样式分离,易于管理和维护

  • 减少页面体积

  • css文件可以被缓存、重用,维护成本降低

2、不使用@import

这条手段已经是众所周知,这里简单提一下,@import影响css文件的加载速度

3、避免使用复杂的选择器,层级越少越好

有时候项目的模块越来越多,功能越来越复杂,我们写的CSS选择器会内套多层,越来越复杂。

建议选择器的嵌套最好不要超过三层,比如:

可以优化成

简洁的选择器不仅可以减少css文件大小,提高页面的加载性能,浏览器解析时也会更加高效,也会提高开发人员的开发效率,降低了维护成本。

4、精简页面的样式文件,去掉不用的样式

很多时候,我们会把所有的样式文件合并成一个文件,但是这样有一个问题:很多其他页面的CSS同时引用到当前页面中,而当前页面并没有用到它们,这种情况会造成两个问题:

  • 样式文件偏大,影响加载速度

  • 浏览器会进行多余的样式匹配,影响渲染时间。

正确的处理方法是根据当前页面需要的css去合并那些当前页面用到的CSS文件。

PS:合并成一个文件有一个优点:样式文件会被浏览器缓存,进入到其他页面样式文件不用再去下载。这条规则应根据场景来区别对待,如果是大项目,应该合并成不同的样式文件,如果是简单的项目,建议合并成一个文件即可。如果无法确认项目规模,建议分开成不同的样式文件,日后要合并也比较方便。

5、利用CSS继承减少代码量

我们知道有一部分CSS代码是可以继承的,如果父元素已经设置了该样式,子元素就不需要去设置该样式,这个也是提高性能的行之有效的方法。

常见的可以继承的属性比如:

color,font-size,font-family等等

不可继承的比如:

position,display,float等

大家可以查看CSS参考手册

提高可维护性的方法

提高CSS代码的可维护性,简单的说就是要让开发人员易于理解CSS代码,容易去修改它,不会破坏原有的功能。下面说说一些常用的手段。

1、命名与备注

命名是提高代码可读性的第一步,也是及其重要的一步。很多人都有这样的体会:命名是写代码中最让程序员头疼的事情之一,尤其是对母语非英语的开发人员来说,要找一个合适贴切的名字并不容易。提高自己命名的能力,可以多看看别人的代码。下面是CSS中的一些命名相关的建议:

头:header

内容:content/container

尾:footer

导航:nav

侧栏:sidebar

栏目:column

页面外围控制整体佈局宽度:wrapper

左右中:left right center

登录条:loginbar

标志:logo

广告:banner

页面主体:main

热点:hot

新闻:news

下载:download

子导航:subnav

菜单:menu

子菜单:submenu

搜索:search

友情链接:friendlink

页脚:footer

版权:copyright

滚动:scroll

内容:content

标签:tags

文章列表:list

提示信息:msg

小技巧:tips

栏目标题:title

加入:joinus

指南:guide

服务:service

注册:regsiter

状态:status

投票:vote

合作伙伴:partner

导航:nav

主导航:mainnav

子导航:subnav

顶导航:topnav

边导航:sidebar

左导航:leftsidebar

右导航:rightsidebar

菜单:menu

子菜单:submenu

标题: title

摘要: summary

2、提取重复样式

这一个方法很容易理解,简单说就是提取相同的样式成为一个单独的类再引用,这样不仅可以精简CSS文件大小,而且CSS代码变少,更易于重用和维护。例如下面的例子:

原来的代码是这样:

这两个样式的区别在于文字颜色的不同,我们可以将其公共的样式提取出来,然后再分别设置其不同的样式

提取公用的部分,然后在页面上分别引用column-title和about等,这样代码更简洁,维护起来也更方便了。这个例子非常简单,实际上项目中可能有更复杂的情况,总之就要要尽可能的DRY,尽可能的提取重复的东西。

3、书写顺序

这个书写顺序指的是各个样式的书写顺序,下面是推荐的CSS书写顺序

  • 位置属性(position, top, right, z-index, display, float等)

  • 大小(width, height, padding, margin)

  • 文字系列(font, line-height, letter-spacing, color- text-align等)

  • 背景(background, border等)

  • 其他(animation, transition等)

书写顺序不一定非得按照上面的推荐来进行,而是根据你自己的习惯,但是最好能保证前后的习惯一致的,或者团队应该有一个共同的代码规范去遵守,这样后期维护起来也会方便许多。

以上是我个人总结的一些简单的写好和重构CSS代码的方法,大家当然不必拘泥于此,有不同的意见和建议欢迎进行交流!

CSS方法论

什么是CSS方法论呢?简单地说就是一些同行为了提高CSS的可维护性、提出的一些编写CSS代码的规范和方法。他们提出了一些概念,这些概念可能听起来很高大上,但是实际你平时可能不知不觉也会用到这些所谓的CSS方法论。下面我简单地介绍下几个比较常见的CSS方法论。

OOCSS

OOCSS是(Object Oriented CSS),顾名思义就是面向对象的CSS。

OOCSS主要有两个原则:

1、结构和样式分离

我们平时一定遇到过这种情况,比如一个页面存在着多个不同功能的按钮,这些按钮的形状大小都差不多,但是根据不同的功能会有不同的颜色或背景来加以区分。如果不进行结构和样式分离,我们的CSS代码可能是这样的

这两个或者可能更多的按钮拥有一些不同的样式,但是它们同时拥有相同的大小样式等,我们将其抽象的部分提取出来,结果如下:

这样提取公用的样式出来,然后按钮同时引用btn和primary等。这种做法除了减少重复的代码精简CSS之外,还有一个好处是复用性,如果需要增加其他额外的按钮,只需要编写不同的样式,和btn配合使用即可。

(2)容器和内容分离

我们平时写代码一定写过这样代码

这样的代码就是内容依赖于容器,没有分离的代码,也就是说h3的样式依赖于.content容器,如果其他地方要用到相同的样式,但是它的容器却不是.content,那你可能就是要再写一遍.something h3。

所以OOCSS推荐分离容器和内容,可以修改成:

关于这一点,我个人建议要分情况来看,像前面这个例子,它适合样式和容器分离。但是比如下面这种情况:

这种ul,li列表的样式,我觉的就按照我们原先的做法就可以,不一定非得给一个类给li来设定样式,即

这样页面的li标签需要引用menu-item类。

当然采用哪一种方式更好我也不却确定,我自己比较喜欢.menu li的写法,大家自行思考。

这就是OOCSS的两个基本原则,这里只是简单介绍OOCSS,各位如果有兴趣的话请自行Google查找相关资料。

SMACSS

SMACSS是什么呢,它的全称是Scalable and Modular Architecture for CSS。简单说就是可扩展和模块化的CSS架构。

SMACSS将样式分成5种类型:Base,Layout,Module,State,Theme,我们简单来说说每一种类型分别指什么。

1、Base

基础样式表,定义了基本的样式,我们平时写CSS比如reset.css就是属于基础样式表,另外我认为清除浮动,一些动画也可以归类为基础样式。

2、Layout

布局样式,用于实现网页的基本布局,搭起整个网页的基本骨架。

3、Module

网页中不同的区域有这个不同的功能,这些功能是相对独立的,我们可以称其为模块。模块是独立的,可重用的组件,它们不依赖于布局组件,可以安全的删除修改而不影响其他模块。

4、State

状态样式,通常和js一起配合使用,表示某个组件或功能不同的状态,比如菜单选中状态,按钮不可用状态等。

关于状态样式,我个人觉得要分情况进行讨论:

  • 不同组件的同一状态的样式是一样的,比如头部的导航菜单的选中状态样式和侧栏的菜单选中状态样式是一样的,我认为这部分状态样式可以归类为State

  • 不同组件的统一状态的样式是不一样的,即两个地方的菜单虽然都是选中状态,但是他们却又不同的选中样式,这部分样式不应该被认为是State类型,而是应该放在其组件对应的Module中。

5、Theme

皮肤样式,对于可更换皮肤的站点来说,这个是很有必要的,分离了结构和皮肤,根据不同的皮肤应用不同的样式文件。

BEM

BEM是Block,Element,Modifier的缩写。下面分别来介绍一下这三个概念:

  • Block:在BEM的理论中,一个网页是由block组成的,比如头部是个block,内容是block,logo也是block,一个block可能由几个子block组成。

  • Element:element是block的一部分,具有某种功能,element依赖于block,比如在logo中,img是logo的一个element,在菜单中,菜单项是菜单的一个element

  • Modifier:modifier是用来修饰block或者element的,它表示block或者element在外观或行为上的改变

我们通过BEM命名法写样式如下:

.block{}

.block-element{}

.block-modifier{}

.block-element-modifier{}

BEM将页面解析为block和element,然后根据不同的状态使用modifier来设置样式。

我对BEM的思想理解可能不到位,对BEM的看法主要是由两点:

(1)页面CSS模块化,每个block就是一个模块,模块间相互独立

(2)多级的class命名,避免选择器的嵌套结构

关于CSS方法论

上面提到的这些CSS方法论,大家看了就会发现,它们其实有很多思想是相同的,比如:

  1. 选择器的嵌套的优化

  2. CSS代码模块化

  3. 抽象CSS代码

这些方法论,我们学习的时候,最重要的是去理解其思想,不一定非得照搬它的实现形式,多种方法结合使用。

我自己总结的方法

谈了这么多,下面来说说我自己总结的写CSS代码的一些关键点。

1、写代码之前:从PSD文件出发

当我们拿到设计师给的PSD时,首先不要急于写CSS代码,首先对整个页面进行分析,主要关注点是下面几个:

  • 页面分成了几个模块,哪些模块是公用的,常见的比如头部和底部,还有一些菜单栏等等

  • 分析每一个模块都有什么样式,提取出公用的样式,注意公用样式是全局公用(整个页面公用)还是局部公用(模块内公用),公用样式包括公用的状态样式,比如公用的选中状态,禁用状态等等。

2、开始写代码

根据对PSD文件的分析,我们就可以开始着手写代码,我比较推荐SMACSS将样式分成不同类型的做法:

  • 第一步是搭好页面的骨架,也就是base样式,layout样式。

  • 第二步就是依次实现不同的模块,在这里我推荐BEM的命名思想,但是可以嵌套一到两层的选择器结构

3、优化代码

我相信当我们完成基本的页面效果后,还是会存在着一些重复的或者不够简洁的代码,这时候就是要去优化这些代码,主要是在提取重复代码,尽可能地精简代码。

关于CSS代码的优化,我相信大家有很多自己的看法,欢迎交流和讨论!

分享到:
评论

相关推荐

    人民邮电(图灵)-CSS重构:样式表性能调优

    人民邮电(图灵)-CSS重构:样式表性能调优.201711.epub 人民邮电(图灵)-CSS重构:样式表性能调优

    CSS重构:样式表性能调优_前端学习_

    CSS重构,主要讲了一本对代码 的一种优化,初学者看看很有帮助

    CSS网站布局实录 (第二版)PDF版

    6.6 CSS代码优化 6.6.1 增加代码重用率 6.6.2 使用样式覆盖进行简化 6.7 园角样式设计 6.7.1 圆角表格 6.7.2 圆角矩形 6.8 滑动门技术 6.9 小提示窗口 6.10 图像地图 6.11 垂直居中 6.12 折叠标签 6.13 CSS数据图表 ...

    homework_01:代码重构

    代码重构 客户希望优化网站,使其具有更多的网络可访问性。 我开始在CSS上合并代码,这样它可以变得更易读和更干净,摆脱了不必要的代码行。 之后,我开始研究HTML,开始看到一些模式。 为了更具体和可访问,需要...

    纯DIV+CSS网页示例

    1.大大缩减页面代码,提高页面浏览速度,缩减带宽成本; 2....你可以将站点上所有的网页风格都使用一个CSS文件进行控制,只要修改这个CSS文件中相应的行,那么整个站点的所有页面都会随之发生变动。

    用于可访问性的重构代码:用于可访问性的重构代码并更正HTML和CSS中的语义(Bootcamp作业)

    重构可访问性代码并更正HTML和CSS(Bootcamp作业)中的语义,使代码对所有人都适用。 请参阅下面的我对HTMl和CSS页面所做更改的评论,这些评论也会在线显示。 对HTML的更改: 向所有图像添加了Alt描述。 将标题...

    代码重构

    家庭作业周1 家庭作业 作为一家营销机构的用户故事,我想要一个遵循可访问性标准的代码库,因此我们自己的网站已针对搜索引擎进行了优化 ...至于仓库,请给它一个唯一的名称,例如代码重构,避免在仓库名称中

    代码重构:重构代码以符合可访问性标准

    代码重构 项目描述 在这个项目中,我的任务是改善公司的代码库,以实现长期的可持续性。 为此,对现有代码进行了重构,使其遵循可访问性标准,从而使客户的网站针对搜索引擎进行了优化。 具体来说,添加了图像的...

    horiseon-refactor-code:Horiseon代码库进行重构,以遵循可访问性标准进行搜索引擎优化

    霍里森重构码目的Horiseon网站代码库进行重构,以遵循可访问性标准来优化搜索引擎。 对代码进行重组以遵循语义结构以及适当的缩进和注释,以使代码易于阅读。建于HTML CSS Web无障碍标准对基本代码所做的更改包含...

    基于SSM框架的jpetstore宠物商店系统重构源码

    本项目是对jpetstore宠物商店系统的重构,采用了SSM(Spring, Spring MVC, MyBatis)框架进行构建,以优化系统的架构和性能。该源码包含了丰富的Java类、清晰的结构化HTML页面、交互式的JavaScript代码以及美化的CSS...

    css-zero:零运行时CSS-in-JS

    生成优化的原子CSS,没有重复的样式规则 基于应用程序顺序而不是层叠的样式解析 支持CSS模块的应用程序的零配置服务器端呈现 样式易于组合,通过静态分析消除了属性名称冲突 通过CSS变量支持主题,使主题化的成本与...

    CSS美化 input type=file 兼容各个浏览器

    在日常重构中,form表单家族中的 upload field 在使用 css 美化时令人头疼!默认情况下,各个浏览器下的表现层次不齐!...经过一番试验,重构组的同学想到一个方案,哈哈,纯CSS实现,代码很简单的哦。 方案如下:

    onthefly:即时生成HTML和CSS

    飞行中 用于同时生成HTML和CSS的软件包。... 与SVG相关的代码已被重构,优化并移至软件包中。 在线API文档 一次性生成HTML,CSS和SVG 使用创建硬件加速的3D图形 实验 示例 package main import ( "fmt

    Homework-Refactor-01:这是第一个星期的家庭作业,用于重构Horiseon着陆页的代码

    01 HTML,CSS和Git:代码重构任务对于此特定的作业,请重构现有站点以使其更易于访问。用户故事作为一家营销机构,必须针对搜索引擎优化该网站。 源代码是根据以下提到的标准验收标准无障碍标准当我查看源代码时,会...

    代码重构:第一周的作业

    * In the CSS code I updated the style coding that was linked to the div tags to match what was in the HTML element of 'nav' instead of 'div'我还修复了“搜索引擎优化”中的“导航ID”问题,以便在单击...

    Code-Refactor:HTML CSS Git

    代码重构资料库该存储库(代码重构)是CARL-OTT-FSF-PT-02-20121-UC课程中的一项教育作业。 它旨在帮助学生熟悉html5属性以及如何实现它们。 还有一个CSS组件,使学生可以更加了解自己的内在联系。部署的网站链接...

    艺帆集团公司企业网站源码 v1.7.5.rar

    最后,需要注意的是,蜘蛛不喜欢一个页面有太多的css代码,否则同样会影响蜘蛛的爬行,影响搜索引擎的收录,所以采用外部调用的方式调用CSS是非常不错的方法。而同时,若非必须太多花哨的网站,采用CSS布局,同样...

    霍里森码重构

    Horiseon代码重构 我参与了这个项目,以重构Horiseon网站上的一些旧标记。 他们要求对HTML进行一些更新,以改善网站的可访问性。 在进行此工作时,我还遇到了HTML和CSS中的其他一些项目,这些项目将提高我更新的...

Global site tag (gtag.js) - Google Analytics