[转]CSS编码规范

简介: 单行形式书写风格的排版约束 1.      每一条规则的大括号 { 前后加空格 2.      多个selector共用一个样式集,则多个selector必须写成多行形式 3.      每一条规则结束的大括号 } 前加空格 4.

单行形式书写风格的排版约束

1.      每一条规则的大括号 { 前后加空格

2.      多个selector共用一个样式集,则多个selector必须写成多行形式

3.      每一条规则结束的大括号 } 前加空格

4.      属性名冒号之前不加空格,冒号之后加空格

5.      每一个属性值后必须添加分号; 并且分号后空格

例如:

div.test { width: 100px; height: 200px; }

a:focus,

a:hover { position: relative; right: 1px; }

多行形式书写风格的排版约束

1.      每一条规则的大括号 { 前添加空格

2.      多个selector共用一个样式集,则多个selector必须写成多行形式

3.      每一条规则结束的大括号 } 必须与规则选择器的第一个字符对齐

4.      属性名冒号之前不加空格,冒号之后加空格

5.      属性值之后添加分号;

其他规范

1.      使用单引号,不允许使用双引号

2.      如果使用CSS3的属性,如果有必要加入浏览器前缀,则按照webkit- / -moz- / -ms- / -o- / std的顺序进行添加,标准属性写在最后,并且属性名称要对齐,例如:

div.animation-demo {

    -webkit-animation: mymove 5s infinite;

        -moz-animation: mymove 5s infinite;

            -o-animation: mymove 5s infinite;

                 animation: mymove 5s infinite;

命名规则书写规范

1、规则命名中,一律采用小写加中划线的方式,不允许使用大写字母或 _

2、命名避免使用中文拼音,应该采用更简明有语义的英文单词进行组合

3、命名注意缩写,但是不能盲目缩写,具体请参见常用的CSS命名规则

4、不允许通过1、2、3等序号进行命名

5、避免class与id重名

6、id用于标识模块或页面的某一个父容器区域,名称必须唯一,不要随意新建id

7、class用于标识某一个类型的对象,命名必须言简意赅。

8、尽可能提高代码模块的复用,样式尽量用组合的方式

9、规则名称中不应该包含颜色(red/blue)、定位(left/right)等与具体显示效果相关的信息。应该用意义命名,而不是样式显示结果命名。

10、除了重置浏览器默认样式外,禁止直接为html tag添加css样式设置,例如:

div {

    width: 200px;

    font-size: 16px;

}

11、每一条规则应该确保选择器唯一,禁止直接为全局.nav/.header/.body等类设置属性

属性编写顺序

推荐的样式编写顺序

1、显示属性

display/list-style/position/float/clear

2、自身属性(盒模型)

width/height/margin/padding/border

3、背景

background

4、行高

line-height

5、文本属性

color/font/text-decoration/text-align/

text-indent/vertical-align/white-space/content

6、其他

cursor/z-index/zoom

7、CSS3属性

transform/transition/animation/box-shadow/border-radius

8、链接的样式请严格按照如下顺序添加:

a:link -> a:visited -> a:hover -> a:active(LoVeHAte)

性能优化

1.      选择器应该在满足功能的基础上尽量简短,减少选择器嵌套,查询消耗。但是一定要避免覆盖全局样式设置。

2.      注意选择器的性能,不要使用低性能的选择器,例如:

div > * {}

ul > li > a {}

body.profile ul.tabs.nav li a {}

3.      禁止在css中使用*选择符

4.      除非必须,否则,一般有class或id的,不需要再写上元素对应的tag,例如:

div#test { width: 100px; }

5.      0后面不需要单位,比如0px可以省略成0,0.8px可以省略成.8px

6.      如果是16进制表示颜色,则颜色取值应该大写。

7.      如果可以,颜色尽量用三位字符表示,例如#AABBCC写成#ABC

8.      如果没有边框时,不要写成border:0,应该写成border:none

9.      尽量避免使用AlphaImageLoader

10.    在保持代码解耦的前提下,尽量合并重复的样式

11.    background、font等可以缩写的属性,尽量使用缩写形式

hack

IE6   * html selector { … }

IE7   *+html selector { … }

非IE6      html>body selector { … }

firefox     @-moz-document url-prefix() { … }

safari3+/chrome    @media screen and (-webkit-min-device-pixel-ratio:0) { … }

opera     @media all and (-webkit-min-device-pixel-ratio:10000), not all and (-webkit-min-device-pixel-ratio:0) { … }

iPhone/mobile webkit   @media screen and (max-device-width: 480px) { … }

z-index取值规范

头部导航区域

[1999 - 2100]

publisher所在的内容head区

[1998]

页面主要内容区域

[-1 - 1997]

页面底部

[1999 - 2100]

首页应用弹层

[1000]

全站公共组件

[-1 - 1999]

全页面蒙层弹窗组件

[10000-11000]

其他

1、字体名称请映射成对应的英文名,例如:黑体(SimHei) 宋体(SimSun) 微软雅黑 (Microsoft Yahei),如果字体名称中有空格,则必须加单引号。

2、背景图片请合理使用csssprites,按照模块、业务、页面来划分均可

3、css背景图片的文件类型,请按照以下原则来保存:

3.1 如果背景图片有动画,则保存成gif

3.2 如果没有动画,也没有半透明效果,则保存成png-8

3.3 如果有半透明效果,则保存成png-24

4、不要在html中加入标签来清理浮动,通过在浮动元素的父元素上添加.clearfix来清除浮动

5、为了SEO和页面可用性,请使用text-indent来隐藏文本内容。

6、制作css sprites时,尽量把颜色相近的图标放在一起,存储为png8格式,存储完以后还能用一些压缩工具进行无损压缩。

7、避免过小的背景图片平铺。

8、尽量少用!important

9、避免使用非一次性expression

目录
相关文章
|
2天前
一个好看的小时钟html+js+css源码
一个好看的小时钟html+js+css源码
64 24
|
4月前
|
前端开发
2s 利用 HTML+css动画实现企业官网效果
2s 利用 HTML+css动画实现企业官网效果
HTML+CSS 实现通用的企业官网页面(记得收藏)
HTML+CSS 实现通用的企业官网页面(记得收藏)
|
1月前
|
前端开发 测试技术 定位技术
如何利用HTML和CSS构建企业级网站的全过程。从项目概述到页面结构设计,再到HTML结构搭建与CSS样式设计,最后实现具体页面并进行优化提升,全面覆盖了网站开发的关键步骤
本文深入介绍了如何利用HTML和CSS构建企业级网站的全过程。从项目概述到页面结构设计,再到HTML结构搭建与CSS样式设计,最后实现具体页面并进行优化提升,全面覆盖了网站开发的关键步骤。通过实例展示了主页、关于我们、产品展示、新闻动态及联系我们等页面的设计与实现,强调了合理布局、美观设计及用户体验的重要性。旨在为企业打造一个既专业又具吸引力的线上平台。
61 7
|
1月前
|
前端开发 JavaScript 搜索推荐
HTML与CSS在Web组件化中的核心作用及前端技术趋势
本文探讨了HTML与CSS在Web组件化中的核心作用及前端技术趋势。从结构定义、语义化到样式封装与布局控制,两者不仅提升了代码复用率和可维护性,还通过响应式设计、动态样式等技术增强了用户体验。面对兼容性、代码复杂度等挑战,文章提出了相应的解决策略,强调了持续创新的重要性,旨在构建高效、灵活的Web应用。
38 6
|
1月前
|
存储 移动开发 前端开发
高效的 HTML 与 CSS 编写技巧,涵盖语义化标签、文档结构优化、CSS 预处理、模块化设计、选择器优化、CSS 变量、媒体查询等内容
本文深入探讨了高效的 HTML 与 CSS 编写技巧,涵盖语义化标签、文档结构优化、CSS 预处理、模块化设计、选择器优化、CSS 变量、媒体查询等内容,旨在提升开发效率、网站性能和用户体验。
45 5
|
1月前
|
前端开发 JavaScript UED
在数字化时代,Web 应用性能优化尤为重要。本文探讨了CSS与HTML在提升Web性能中的关键作用及未来趋势
在数字化时代,Web 应用性能优化尤为重要。本文探讨了CSS与HTML在提升Web性能中的关键作用及未来趋势,包括样式表优化、DOM操作减少、图像优化等技术,并分析了电商网站的具体案例,强调了技术演进对Web性能的深远影响。
39 5
|
2月前
|
前端开发 JavaScript 搜索推荐
打造个人博客网站:从零开始的HTML和CSS之旅
【9月更文挑战第32天】在这个数字化的时代,拥有一个个人博客不仅是展示自我的平台,也是技术交流的桥梁。本文将引导初学者理解并实现一个简单的个人博客网站的搭建,涵盖HTML的基础结构、CSS样式的美化技巧以及如何将两者结合来制作一个完整的网页。通过这篇文章,你将学会如何从零开始构建自己的网络空间,并在互联网世界留下你的足迹。
|
1月前
|
JSON 移动开发 数据格式
html5+css3+js移动端带歌词音乐播放器代码
音乐播放器特效是一款html5+css3+js制作的手机移动端音乐播放器代码,带歌词显示。包括支持单曲循环,歌词显示,歌曲搜索,音量控制,列表循环等功能。利用json获取音乐歌单和歌词,基于html5 audio属性手机音乐播放器代码。
120 6

热门文章

最新文章