前端代码整洁与规范之CSS篇

一、代码整洁

1. 命名规范

CSS 类名的命名应该简洁清晰,能够准确描述元素的作用。避免使用无意义的名称,例如“a”、“b”等,而应该使用有意义的英文单词或单词缩写。同时,也要避免使用驼峰命名法和下划线命名法混杂使用,要保持一致性。

正确的类名命名示例:

.button {...
}.link-button {...
}input[type="text"] {...
}

2. 代码缩进

CSS 代码的缩进对代码的可读性和语义性有很大的影响。建议使用四个空格或两个空格的缩进,而不是制表符。代码缩进应该有层次感,使代码结构清晰易读。

正确的代码缩进示例:

.container {padding: 10px;
}

3. 避免冗余代码

在编写 CSS 代码时,应该避免冗余的代码。尽量将通用的样式合并在一起,避免重复定义样式。同时,也要避免不必要的样式设置,保持代码精简。

4. 注释规范

在 CSS 代码中适当添加注释,可以帮助其他开发者更好地理解代码。注释应该清晰明了,描述代码的作用和用法。同时,也要避免添加过多的注释,以免影响代码的可读性。

示例注释:

/* This is a button style */
.button {...
}/* This is a container style */
.container {...
}

二、代码规范

1. 使用属性简写

在编写 CSS 代码时,尽量使用属性简写,而不是分别设置每个属性。属性简写可以减少代码量,提高代码的可读性和维护性。

属性简写示例:

/* 使用属性简写 */
.container {margin: 10px 20px;
}/* 不使用属性简写 */
.container {margin-top: 10px;margin-right: 20px;margin-bottom: 10px;margin-left: 20px;
}

2. 统一样式格式

在 CSS 代码中,应该统一样式的格式,例如统一使用单引号或双引号、统一使用分号结尾等。这样可以提高代码的一致性和可读性。

样式格式示例:

/* 统一使用双引号 */
.button {font-family: "Arial", sans-serif;
}/* 统一使用分号结尾 */
.button {color: red;
}

3. 使用CSS预处理器

CSS 预处理器可以帮助开发者更高效地编写 CSS 代码,提高代码的可维护性。常见的 CSS 预处理器有 SASS、LESS、Stylus 等,它们提供了变量、嵌套、Mixin 等功能,让 CSS 代码更加灵活和简洁。

使用SASS示例:

$primary-color: #007bff;.button {background-color: $primary-color;
}.container {margin: 10px;
}

4. 浏览器兼容性

在编写 CSS 代码时,要注意浏览器兼容性问题。尽量避免使用浏览器特有的样式和属性,保持代码的通用性。同时,也要及时更新浏览器前缀,确保样式在各个浏览器上都能正常显示。

兼容性示例:

/* 使用兼容性前缀 */
.button {-webkit-border-radius: 5px;border-radius: 5px;
}/* 浏览器特有样式 */
@supports (-ms-accelerator:true) {.button {-ms-accelerator: "none";}
}

5. 避免使用全局样式

全局样式是指能够影响整个页面的样式,比如 body 元素或者 * 选择器。虽然在某些情况下使用全局样式会很方便,但是过度依赖全局样式会增加代码的复杂度,降低代码的可维护性。在编写 CSS 代码时,应该尽量避免使用全局样式,而是优先使用类名和 ID 来控制样式。

6. 避免使用 !important

!important 是 CSS 中的一个关键字,用来给样式声明一个高优先级。尽管 !important 可以帮助我们解决一些样式覆盖的问题,但是过度使用 !important 会增加样式的耦合性,导致代码难以维护。在编写 CSS 代码时,我们应该尽量避免使用 !important,而是优先选择更好的解决方案。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/744995.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

十大经典排序之选择排序

文章目录 概要整体架构流程代码实现小结 概要 选择排序是一种简单直观的排序算法,无论什么数据进去都是 O(n) 的时间复杂度。所以用到它的时候,数据规模越小越好。唯一的好处可能就是不占用额外的内存空间了吧。 整体架构流程 首先在未排序序列中找到…

NAND闪存市场格局或将发生变化

随着供应商有效减产,内存价格开始反弹,半导体内存市场终于呈现复苏迹象。从市场动态和需求变化来看,作为两大内存产品之一的NAND闪存正经历新一轮变革。 供应商不断采取行动,提高价格并调整产能利用率。自2023年第三季度以来&…

Live800:企业如何与客户建立长期、稳定关系,实现双赢

在当今的商业环境中,企业不仅需要吸引新客户,更需要与现有客户建立长期、稳定的关系。这样的关系可以带来持续的收入,提高企业的利润性。然而,如何建立和维护这样的关系呢?文章将从三个方面进行深入探讨:提…

SpringBoo和vue项目blob传参未生效

学无止境,气有浩然 文章目录 前言展示问题代码问题解决打完收工! 前言 工作里做的一个小工具,axios传参,使用FormData传参到后端,没有办法映射除字段值,但是从控制台看,传的字段值都是正确的&a…

Milvus向量数据库检索

官方文档:https://milvus.io/docs/search.md   本节介绍如何使用 Milvus 搜索实体。   Milvus 中的向量相似度搜索会计算查询向量与具有指定相似度度量的集合中的向量之间的距离,并返回最相似的结果。您可以通过指定过滤标量字段或主键字段的布尔表达…

Javaweb-MyBatis

一、概念 MyBatis是一款优秀的持久层框架,用于简化JDBC开发 MyBatis本是Apache的一个开源项目iBatis,2010年这个项目由apache software found迁移到了google code,并且改名为MyBatis。2013年11月迁移到Github 持久层 负责将数据到保存到数…

科技云报道:两会热议的数据要素,如何拥抱新技术?

科技云报道原创。 今年全国两会上,“数字经济”再次成为的热点话题。 2024年政府工作报告提到:要健全数据基础制度,大力推动数据开发开放和流通使用;适度超前建设数字基础设施,加快形成全国一体化算力体系&#xff1…

低代码与数字化工具:重塑软件开发的新范式

随着信息技术的飞速发展,软件开发已成为推动数字化转型的核心力量。在这个变革的时代,低代码与数字化工具逐渐崭露头角,它们不仅简化了开发过程,还大大提高了开发效率,成为推动软件开发领域变革的重要力量。 低代码&am…

面试经典-11-接雨水

题目 给定 n 个非负整数表示每个宽度为 1 的柱子的高度图,计算按此排列的柱子,下雨之后能接多少雨水。 示例 1: 输入:height [0,1,0,2,1,0,1,3,2,1,2,1] 输出:6 解释:上面是由数组 [0,1,0,2,1,0,1,3,2,…

2024自动化测试的痛点与发展趋势!

前几天在技术交流群里,大家讨论了很多关于自动化测试落地面临的痛点和如何创造价值的话题,颇有感触。 自动化测试这个话题,从出现到在国内大规模开展实践,有很长的一段时间了。早期,大家对自动化测试的理解和使用目的…

java:学生管理系统

一、介绍 该功能是实现学生信息的添加,查看,修改,删除以及退出系统的简单操作。 二、代码实现 public class Student {private String sid;//学号private String name;//姓名private String age;//年龄private String address;//地址publi…

通过NFS 实现windows共享linux目录

一、配置WIndows 1.进入程序和功能 2.勾选NFS服务,安装客户端 二、安装NFS Service 在ubuntu 1.查看apt源是否存在nfs服务端安装包 sudo apt-cache madison nfs-kernel-server 2. 安装nfs-kernel-server sudo apt install nfs-kernel-server 3.建立共享目录&…

Compose UI 之 BottomAppBar 底部应用栏

BottomAppBar 底部应用栏 BottomAppBar 是一个在 Jetpack Compose 中用于创建底部应用栏的组件。它提供了一个高度可定制且功能丰富的底部导航解决方案。 它的使用方式与 TopAppBar 类似。下面的图是 BottomAppBar 的基本样式图。 常见使用场景 BottomAppBar 在应用中常用于…

代码随想录算法训练营第22天 | 235. 二叉搜索树的最近公共祖先、701. 二叉搜索树中的插入操作、450. 删除二叉搜索树中的节点

235. 二叉搜索树的最近公共祖先 题目链接 235. 二叉搜索树的最近公共祖先 - 力扣(LeetCode) 思路 因为二叉搜索树是有序的,那么就可以向二分法一样去有向的搜索。 //---------------------------递归法---------------------------// cl…

人工智能课题、模型源码

人工智能研究生毕业~深度学习、计算机视觉、时间序列预测(LSTM、GRU、informer系列)、python、人工智能项目代做和指导,各种opencv图像处理、图像分类模型(vgg、resnet、mobilenet、efficientnet等)、人脸检…

ESD静电测试闸机-筑成电子厂防静电管理的第一道防线

ESD静电测试闸机是一种用于防止静电对电子产品和设备造成损害的重要设备。在电子厂等对静电敏感的场所,ESD静电测试闸机扮演着防静电管理的第一道防线的角色,确保生产环境的安全和产品质量的稳定。本文将从静电监测和消除、刷卡/身份证认证、指纹/人脸识…

Tengine编译安装

首先下载源码 可以去官网:The Tengine Web Server 当前最新版地址:https://tengine.taobao.org/download/tengine-3.1.0.tar.gz 安装编译依赖 yum -y install gcc pcre-devel zlib-devel openssl-devel libxml2-devel \libxslt-devel gd-devel GeoIP…

Java的锁机制,线程池机制在项目中应用

Java的锁机制是Java多线程编程中用于保护共享资源的一种机制。Java提供了多种类型的锁,包括synchronized关键字和Lock接口。 synchronized关键字:synchronized关键字可以用于方法或代码块级别的同步。当一个线程进入synchronized块时,它将获得…

一款前端开发工具Hbuilder

背景:最近日在接触前同事留下的一个VUE项目(只有前端代码,后台服务压根没写真不知道以前是怎么糊弄过去的)时,发现一款可以快速开发前端的软件;今日分享一下。 当我打开项目时发现,有个app.vue…

【Cookie和Session辨析】

1.cookie 1.1什么是cookie Cookie 是一种在客户端(通常是 Web 浏览器)和服务器之间传递信息的机制,用于在客户端存储少量的数据。它由服务器发送到客户端浏览器,然后浏览器会将这些数据存储在本地,并在后续的请求中将…