CSS代码重构详解

本文主要介绍css代码重构,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧,希望能帮助到大家。

1. 重构和架构

重构是指在不改变代码行为的前提下,重写代码,使其更加简洁、易于复用。

架构是指软件项目的各个不同部件之间的组合方式。

优秀的架构:

立即学习“前端免费学习笔记(深入)”;

可预测:可以对软件的工作方式和结构做出准确的假设

可复用:在多处使用同一代码,无需重写

可扩展:比较容易的增加新内容

可维护:修改一处代码不用大规模的改动其他代码

2. CSS选择器的优先级

用(a, b, c, d)表示,优先级 a>>b>>c>>d,其中:

有行内 style 属性时,a=1,否则 a=0

b 为 ID 选择器的数量

c 为类选择器、属性选择器、伪类的数量

d 为类型选择器、伪元素的数量

(ps:伪类和伪元素的区别)

!important 优先级最高,可覆盖行内样式。不可以添加到行内样式属性中。

3. 如何编写优质的 CSS

使用注释

注释记录的内容包括:

文件内容

选择器的依赖、用法

使用特定声明的原因(hack等)

不应继续使用的废弃样式

/** 导航链接样式** @see templates/nav.html*/.nav-link {  ...}.nav-link:hover {  border-bottom: 4px solid #333;  /* 防止增加了4px下边框导致元素移动 */  padding-bottom: 0;}/* @deprecated */.nav-link {  ...}

登录后复制

保持选择器的简单

/* 不推荐 */p > nav > ul > li > a {}/* 不推荐 */a.nav-link {}/* 推荐 */.nav-link {}

登录后复制

但是并不是任何场景都应遵循该推荐,如下为输入框的文本和边框增加样式。

.error {  color: #f00;}input.error {  border-color: #f00;}

登录后复制

分离 CSS 和 JavaScript

JavaScript 中用来选择元素的类和 ID, 不应该 再用来为元素添加样式。用 JavaScript 修改元素样式时,应该通过增加和删除 类 来实现。

推荐在只用于 JavaScript 的类和 ID 前添加 js- ,或者 ID 只用于 JavaScript 选择元素,类用于样式。

ID和类名要有意义

创建更好的盒子

盒子的尺寸计算方法有 content-box 和 border-box ,推荐在一个项目中坚持使用一种方法,例如:

*,*::after,*::before {}

登录后复制

(ps: ::after 表示法是在 CSS3 中引入的, :: 符号是用来区分伪类和伪元素的。支持CSS3的浏览器同时也都支持CSS2中引入的表示法 :after ,IE8仅支持 :after )

为样式分类

按用途定义样式,有助于创建更优秀的架构,因为将样式组织为不同的类别,促使代码可预测性更强,更易于复用。

通用样式

因为不同浏览器的默认样式有些许差别,所以需要 通用样式 为各种元素的属性设置默认值样式,使其在不同浏览器

表现一致。

推荐 Nicolas Gallagher 和 Jonathan Neal 开发的normalize.css,可根据自己的项目适当删减。

基础样式

用类型选择器和结合符(例如,ul ul表示ul下面的ul)或者伪类为 HTML 元素添加更加细致的样式。比如: color 、 font-family 、 font-size 、 letter-spacing 、 line-height 、 margin 、 padding 等。

HTML 元素可分为:区块元素、标题和文本元素、锚点元素、文本语义元素、列表、表格、表单等等,不同的元素在基础样式的设置上稍有不同,可参考 元素基础样式表

组件样式

组件重要的是可复用性,如:按钮、下拉菜单、模态框、选项卡等。

定义需要实现的行为,即该组件达到的效果,组织 HTML 结构

为组件里的元素增加样式,确保复用性

根据需要,改写元素容器的样式。如确认按钮,警告按钮,成功按钮等,定义组件的容器元素不同的类名

尺寸在组件的父元素中设置

功能样式

合理使用 !important 定义类属性,在 JavaScript 操作样式时使用。如添加下面这个类来实现元素隐藏:

.hidden {  display: none !important;}

登录后复制

浏览器特定样式

尽管未来浏览器行为趋于统一,但目前一些老的浏览器仍然有怪癖行为。我们不得不使用一些 hack 的样式来解决这些怪癖行为,推荐将这些样式单独放在一个样式表中,并用 条件注释 添加引用。

登录后复制

维护代码

代码规范

代码规范是将良好的代码编写方法记录下来形成指南,以鼓励团队所有成员以相同的方法编写代码。规范应定期审阅和更新。CSS 代码规范通常指定了注释、格式、命名、选择器用法等方便的规范。

模式库

模式库是网站使用的一组用户界面模式,将所有组件汇集在一起。好处就是参与项目的成员都能了解到搭建网站的各个模块,熟悉背后的原理,并且有助于保证用户界面的一致性。

推荐几个优秀的模式库:

Mailchimp’s Pattern Library

[Carbon Design System](http://carbondesignsystem.com/style/color/swatches)

Code For America

代码的组织和重构策略

按照样式从最不精确到最精确组织 CSS

之前我们为样式分类,现在我们按照产生作用的顺序再来组织一下 CSS 代码:

通用样式:设定基准,消除不同浏览器之间的不一致性

基础样式:为网站所有元素提供基本的样式,如颜色、间距、行高、字体等,不需要重写

组件及容器样式:以上一步的基础样式为基础,用类定义样式

结构化样式:该样式常用来创建布局,定义尺寸等

功能样式:最精确的样式,满足单一目的而实现的样式,如警告框样式

浏览器特定样式

PS:媒体查询要靠近相关声明块,这样做可以为样式是如何起作用的提供更多的背景信息。

重构前审查 CSS

如下审查非常有助于重构:

所用到的属性列表

颜色数量

使用的最高和最低选择器优先级

选择器长度

CSS Dig 是 Google Chrome 的一款插件,可以帮助获取以上信息。

重构策略

推荐多次小范围重构,避免大范围重构引入错误。

(1)删除僵尸代码:

没有使用的声明块、重复的声明块和声明语句。

(2)分离 CSS 和 JavaScript

(3)分离基础样式

如果一个类型选择器使用过多次,新建一条规则集,找到最常用的属性,添加到新的规则集。从其他规则集删除重复的属性,因为它们可以继承新定义的基础样式。

/* 重构前 */body > p > h1 {  color: #000;  font-size: 32px;  margin-bottom: 12px;}.section-condensed h1 {  color: #000;  font-size: 16px;}.order-form h1 {  color: #333;  text-decoration: underline;}/* 重构后 */h1 {  color: #000;  font-family: Helvetica, san-serif;  font-size: 32px;  line-height: 1.2;}body > p > h1 {  margin-bottom: 12px;}.section-condensed h1 {  font-size: 16px;}.order-form h1 {  color: #333;  text-decoration: underline;}

登录后复制

(4)删除冗余的 ID

/* 不推荐 */#main-header ul#main-menu {}/* 推荐 */#main-menu {}

登录后复制

(5)定义可复用的组件,删除重复的 CSS

(6)删除行内 CSS

相关推荐:

谈一谈PHP的代码重构_PHP教程

谈一谈PHP的代码重构_PHP教程

谈一谈PHP的代码重构_PHP教程

以上就是CSS代码重构详解的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2900314.html

(0)
上一篇 2025年3月10日 23:56:16
下一篇 2025年2月22日 14:49:12

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • css怎么做出六边形图片

    这次给大家带来css怎么做出六边形图片,css做出六边形图片的注意事项有哪些,下面就是实战案例,一起来看一下。 用简单的div配合伪元素,即可‘画出’这幅六边形图片,原理是三个相同宽高的div,通过定位旋转拼合成一个六边形,再利用背景图层叠…

    编程技术 2025年3月10日
    100
  • CSS和JS实现唯美星空轨迹运动效果

    本文主要和大家分享一个使用css+js实现的唯美星空轨迹运动效果,效果非常逼真,下面小编给大家带来了实例代码,需要的朋友参考下,希望能帮助到大家。 先给大家分享效果图:   给大家分享一个使用CSS+JS实现的唯美星空轨迹运动效果, 这样的…

    2025年3月10日
    200
  • CSS选择器字段解析的实现方法

    根据上面所学的css基础语法知识,现在来实现字段的解析。首先还是解析标题。打开网页开发者工具,找到标题所对应的源代码。本文主要介绍了css选择器实现字段解析的相关资料,需要的朋友可以参考下,希望能帮助到大家 发现是在p class=&#82…

    2025年3月10日 编程技术
    200
  • CSS如何实现Tab页切换的代码分享

    tab页面切换的功能我们已经和大家分享过很多,本文我们主要和大家绍css实现tab页切换实例代码,需要的朋友可以参考下,希望能帮助到大家。 1.hover 移入其父元素.navI时,触发鼠标的hover态,给父元素添加样式为position…

    编程技术 2025年3月10日
    200
  • CSS使用position:sticky实现粘性布局实例详解

    本文主要和大家介绍css使用position:sticky 实现粘性布局的方法的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧,希望能帮助到大家。 简介 前面写了一篇文章讲解了position常用的几个…

    2025年3月10日
    200
  • CSS里的BFC和IFC的用法实例分析

    之前一直听到有人提到 css里的bfc,正巧在 ife的练习里遇到了外边距折叠的问题,所以正好弄清楚bfc的机制。 (参考来源 见文末的 reference) 本文主要和大家介绍CSS里的BFC和IFC的用法的相关资料,小编觉得挺不错的,现…

    2025年3月10日 编程技术
    200
  • CSS定位实例讲解

    本文主要和大家介绍css定位的教程,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧,希望能帮助到大家。 1.文档流 简单说就是元素按照其在 HTML 中的位置顺序决定排布的过程。HTML的布局机制就是用文档流模型…

    编程技术 2025年3月10日
    200
  • CSS圆形缩放动画实现代码分享

    最近在做公司的登录页,ue同学希望第三方登录的图标在hover的时候有一个圆形的缩放效果(原话是波纹效果-_-||),效果参考腾讯新闻和网易新闻的分享按钮。 本文主要和大家介绍CSS圆形缩放动画简单实现的相关资料,小编觉得挺不错的,现在分享…

    2025年3月10日
    200
  • 三种css方法实现DIV居中

    本文主要和大家分享css实现p居中的方法,css代码简单易懂,非常不错,具有参考借鉴价值,需要的朋友参考下,希望能帮助到大家。 下面给大家分享p居中的实现代码,具体代码如下所示: demo .p1{ width: 100px; height…

    2025年3月10日 编程技术
    200
  • 关于Css3的inline-block遇到的坑

    关于inline-block可能很多人都不熟悉,布局这方面很多人用的都是flex或者浮动,flex很强大毋庸置疑的可是关于兼容性就不是很让人满意,而浮动虽然很兼容可是觉得清除浮动就很麻烦,于此我在一些大型网站,例如我们的segmentfau…

    2025年3月10日 编程技术
    200

发表回复

登录后才能评论