翻译自 《CSS Naming and Writing Specification》
例如:php
“工具”是指与业务逻辑解耦的,可以重用的样式;“元件”是指自定义的可重用且可移植的基本网页元素;“挂钩”是指供JavaScript操纵的样式。
以上的说明只是举例,你们能够根据项目需求自定义开头的字符,这样作的目的是使CSS代码整洁易维护。css
推荐的写法:web
.g-first-header
{
line-height: 16px;
}复制代码
不推荐的写法:浏览器
.g-FirstHeader
{
line-height: 16px;
}复制代码
除最后一个选择器外,其它每一列选择器均以逗号结尾。若用到兄弟元素选择器,则相关符号的左右两端均留出一个半角空格。ide
推荐的写法:模块化
.g-first-header,
.g-second-header-1 > .g-second-header-2
{
border: 2px solid #C3C3C3;
}复制代码
不推荐的写法:工具
.g-first-header, .g-second-header-1>.g-second-header-2
{
border: 2px solid #C3C3C3;
}复制代码
构建选择器时应尽可能采用语义明确的类别名称,避开HTML标记,由于一旦HTML的结构产生更动,则与此对应的样式也就无效了。尽可能将样式与结构分离,这样会使得阶层式样式表在往后更易被维护。布局
推荐的写法:性能
.g-content .g-item
{
flex-basis: 20%;
}复制代码
不推荐的写法:字体
.g-content li
{
flex-basis: 20%;
}复制代码
ID的惟一性注定了它所对应的元素的样式就是一次性的,没法重用,一旦HTML结构发生变化,套用ID的选择器就要随之修改。另外一个重要的缘由是:ID的权重值是最高的,这可能会致使往后添加的样式没法复写原先的样式。
推荐的写法:
.g-special-content
{
height: 100px;
width: 300px;
}复制代码
不推荐的写法:
#special-content
{
height: 100px;
width: 300px;
}复制代码
每条规则下的属性在书写时,应按类别进行分组,其排列顺序以下:
有些属性是能够合在一块的,既精简代码,又便于阅读。
推荐的写法:
.test-selector-1
{
padding: 3px 5px;
}复制代码
不推荐的写法:
.test-selector-1
{
padding-top: 3px;
padding-right: 5px;
padding-bottom: 3px;
padding-left: 5px;
}复制代码
推荐的写法:
.test-selector-2
{
font-size: .5em;
}复制代码
不推荐的写法:
.test-selector-2
{
font-size: 0.5em;
}复制代码
推荐的写法:
.test-selector-3
{
background-color: #0b0;
}复制代码
不推荐的写法:
.test-selector-3
{
background-color: #00bb00;
}复制代码
对于“font-family”属性来讲,咱们一般会以引号夹住带有空格的字体名称,而对于不具有这些特征的通常字体来讲,引号存在与否并不影响页面的显示效果。为了保证视觉上的统一,最大程度相容各类浏览器,建议你在全部字体名称的两端均加上引号。
推荐的写法:
.test-selector-4
{
font-family: "Microsoft YaHei", "微软正黑体", "\5b8b\4f53";
}复制代码
不推荐的写法:
.test-selector-4
{
font-family: "Microsoft YaHei", 微软正黑体, \5b8b\4f53;
}复制代码
个别属性的值含有“url()”字串,开发者须要往其中传入一个资源路径。请注意,在低版本的Internet Explorer中,路径中的空格有可能没法被辨识,致使资源没法被找到。为保险起见,不论路径中是否含有空格,你传入的路径两端最好都加上引号。
推荐的写法:
.test-selector-5
{
background-image: url(“../Images/BacPic.png”);
}复制代码
不推荐的写法:
.test-selector-5
{
background-image: url(../Images/BackPic.png);
}复制代码
“!important”会给往后的维护带来麻烦,使开发者难以查找样式问题。若是在书写时发现新样式没法复写旧样式。一般有两个缘由:要么新样式写在了旧样式的前面,要么新样式对应的选择器的权重比旧样式的更低。针对后一种状况,只要增长新样式选择器的权重值就能够彻底避开这个问题,无需用到“!important”。
推荐的写法:
.test-selector-6 .test-selector-7
{
font-size: 16px;
}
.test-selector-6 .test-selector-7 .test-selector-8
{
font-size: 14px;
}复制代码
不推荐的写法:
.test-selector-6 .test-selector-7
{
font-size: 16px;
}
.test-selector-8
{
font-size: 14px !important;
}复制代码
在单列注释中,星号与内容之间留一个半角空格。
推荐的写法:
/* 这是第一段注释文字。 */
// 这是第二段注释文字。复制代码
不推荐的写法:
/*这里是一段注释文字。*/
//这是第二段注释文字。复制代码
在多列注释中,多个星号要排成一条线。星号与内容之间一样留一个半角空格。
推荐的写法:
/** * 这里是一段注释文字。 * 这是第二段注释文字。 */复制代码
不推荐的写法:
/** *这里是一段注释文字。 *这是第二段注释文字。 */复制代码
在文档注释中,除了要按照多列注释的写法之外,还要用标识符来讲明文档中的某一部分,标识符后的冒号右侧与说明文字之间留一个半角空格。
推荐的写法:
/** * @name: 文件名; * @description: 描述文字; * @author: 张3、李四; * @update: 2018年12月19日。 */复制代码
不推荐的写法:
/** * @name:文件名; * @description:描述文字; * @author:张3、李四; * @update:2018年12月19日。 */复制代码
有些属性在部分浏览器中还没有彻底标准化,每家浏览器开发商对这些属性的实现效果或许并不统一,所以目前须要在开头加入浏览器厂商的专有字符串。所以同一个属性须要写屡次,但有一条须要注意:将不带前置标记的属性置于最下方。
推荐的写法:
.test-selector-9
{
opacity: 0;
-webkit-transition: opacity 3s;
-moz-transition: opacity 3s;
-ms-transition: opacity 3s;
-o-transition: opacity 3s;
transition: opacity 3s;
}复制代码
不推荐的写法:
.test-selector-9
{
opacity: 0;
-webkit-transition: opacity 3s;
transition: opacity 3s;
-moz-transition: opacity 3s;
-ms-transition: opacity 3s;
-o-transition: opacity 3s;
}复制代码
每一个属性独占一列。紧接样式属性的冒号,其后面要留一个半角空格。值以分号结尾。
推荐的写法:
.test-selector-10
{
opacity: .5;
}复制代码
不推荐的写法:
.test-selector-10
{
opacity:.5
}复制代码
样式选择器及其样式块与周遭内容要保留一空行以免内容过于拥挤,妨碍寻找。
推荐的写法:
.test-selector-11
{
opacity: 0.5;
}
.test-selector-12
{
font-size: 16px;
}
.test-selector-13
{
overflow: hidden;
}复制代码
不推荐的写法:
.test-selector-11
{
opacity: 0.5;
}
.test-selector-12
{
font-size: 16px;
}
.test-selector-13
{
overflow: hidden;
}复制代码
同一属性的值不止一个或值过长时,以逗号分割这些值,每一个逗号后添加一个空格,过长的值能够另起一列。
推荐的写法:
.test-selector-14
{
linear-gradient(135deg, deeppink 25%, transparent 25%) - 50px 0,
linear-gradient(225deg, deeppink 25%, transparent 25%) - 50px 0,
linear-gradient(315deg, deeppink 25%, transparent 25%),
linear-gradient(45deg, deeppink 25%, transparent 25%);
}复制代码
不推荐的写法:
.test-selector-14
{
linear-gradient(135deg, deeppink 25%, transparent 25%) - 50px 0, linear-gradient(225deg, deeppink 25%, transparent 25%) - 50px 0, linear-gradient(315deg, deeppink 25%, transparent 25%), linear-gradient(45deg, deeppink 25%, transparent 25%);
}复制代码
所谓“CSS Hack”,就是在样式表中加入少量特殊符号,让可以辨识不一样符号的浏览器在同一个元素上计算出来的样式各不相同。出现CSS Hack的缘由就在于老式的浏览器(诸如饱受诟病的Internet Explorer 6)对同一套样式表的计算结果与其它浏览器的并不相同,这就颇有可能会形成版式上的错乱。所以在过去,咱们一般要针对个别怪异的浏览器撰写有针对性的CSS。如width: 300px; _width: 200px;对其它浏览器来讲,该选择器的宽度值应为300个像素,但IE 6可以辨识出底线,所以它计算出的宽度就是200个像素。
样式表中不要含有过多的滤镜表达式和repeat关键字等,这些属性会下降网页的渲染性能。若要重复背景图片,那么原图的宽高各不小于8px。