1.前言
本文档的目标是使研发中心的各位同学html能够按照统一规范进行编写,使其风格保持一致,便于理解和维护。
2.代码风格
2.1 缩进,空格
[强制] 使用 2 个空格做为一个缩进层级,不允许使用 4 个空格 或 tab 字符。(注:对于非 HTML 标签之间的缩进,比如 script 或 style 标签内容缩进,与 script 或 style 标签的缩进同级。)
示例:
<style>
/* 样式内容的第一级缩进与所属的 style 标签对齐 */
ul {
padding: 0;
}
</style>
<ul>
<li>first</li>
<li>second</li>
</ul>
<script>
// 脚本代码的第一级缩进与所属的 script 标签对齐
require(['app'], function (app) {
app.init();
});
</script>
}
2.2 行长度
[建议] 每行不得超过 120 个字符,除非单行不可分割。(注:过长的代码不容易阅读与维护。但是考虑到 HTML 的特殊性,不做硬性要求。)
2.3 命名
- [强制] class 驼峰命名。
- [强制] class 必须代表相应模块或部件的内容或功能,不得以样式信息进行命名。
- [强制] 元素 id 必须保证页面唯一。(注:同一个页面中,不同的元素包含相同的 id,不符合 id 的属性含义。并且使用 document.getElementById 时可能导致难以追查的问题)
- [强制] 禁止为了 hook 脚本,创建无样式信息的 class。(注:不允许 class 只用于让 JavaScript 选择某些元素,class 应该具有明确的语义和样式。否则容易导致 CSS class 泛滥。使用 id、属性选择作为 hook 是更好的方式。)
示例:
<!-- good -->
<div class="sideBar"></div>
<!-- bad -->
<div class="left"></div>
2.4 标签
- [强制] 标签名必须使用小写字母。
- [强制] 对于无需自闭合的标签,不允许自闭合。(注:常见无需自闭合标签有 input、br、img、hr 等。)
- [强制] 标签使用必须符合标签嵌套规则。(注:比如 div 不得置于 p 中,tbody 必须置于 table 中。)
- [建议] HTML 标签的使用应该遵循标签的语义。
- [建议] 标签的使用应尽量简洁,减少不必要的标签。
示例:
<!-- good -->
<p>Hello StyleGuide!</p>
<!-- bad -->
<P>Hello StyleGuide!</P>
<!-- good -->
<input type="text" name="title">
<!-- bad -->
<input type="text" name="title" />
2.4 属性
- [强制] 属性名必须使用小写字母。
- [强制] 属性值必须用双引号包围。(注:不允许使用单引号,不允许不使用引号。)
示例:
<!-- good -->
<table cellspacing="0">...</table>
<!-- bad -->
<table cellSpacing="0">...</table>
<!-- bad -->
<script src='esl.js'></script>
<script src=esl.js></script>
2.5属性
- [强制] 属性定义必须另起一行。
- [强制] 属性定义后必须以分号结尾。
示例:
/* good */
.selector {
margin: 0;
padding: 0;
}
/* bad */
.selector { margin: 0; padding: 0; }
/* good */
.selector {
margin: 0;
}
/* bad */
.selector {
margin: 0
}
3.通用
3.1 DOCTYPE
- [强制] 使用 HTML5 的 doctype 来启用标准模式,建议使用大写的 DOCTYPE。
- [建议] 在 html 标签上设置正确的 lang 属性。(注:有助于提高页面的可访问性,如:让语音合成工具确定其所应该采用的发音,令翻译工具确定其翻译语言等。)
示例:
<!DOCTYPE html>
<html lang="zh-CN">
3.2 编码
[强制] 页面必须使用精简形式,明确指定字符编码。指定字符编码的 meta 必须是 head 的第一个直接子元素。
示例:
<html>
<head>
<meta charset="UTF-8">
......
</head>
<body>
......
</body>
</html>
<html lang="zh-CN">
3.3 CSS 和 JavaScript 引入
- [强制] 引入 CSS 时必须指明 rel="stylesheet"。
- [建议] 引入 CSS 和 JavaScript 时无须指明 type 属性。(注:text/css 和 text/javascript 是 type 的默认值。)
- [建议] 在 head 中引入页面需要的所有 CSS 资源。(注:在页面渲染的过程中,新的CSS可能导致元素的样式重新计算和绘制,页面闪烁。)
- [建议] JavaScript 应当放在页面末尾,或采用异步加载。(注:将 script 放在页面中间将阻断页面的渲染。出于性能方面的考虑,如非必要,请遵守此条建议。)
示例:
<link rel="stylesheet" href="page.css">
<body>
<!-- a lot of elements -->
<script src="init-behavior.js"></script>
</body>
4.head
4.1 title
[强制] 页面必须包含 title 标签声明标题。(注:title 中如果包含 ASCII 之外的字符,浏览器需要知道字符编码类型才能进行解码,否则可能导致乱码。)
示例:
<head>
<meta charset="UTF-8">
<title>页面标题</title>
</head>
4.2 favicon
[强制] 保证 favicon 可访问。在未指定 favicon 时,大多数浏览器会请求 Web Server 根目录下的 favicon.ico 。为了保证 favicon 可访问,避免 404,必须遵循以下两种方法之一:
- 在 Web Server 根目录放置 favicon.ico 文件。
- 使用 link 指定 favicon。
示例:
<link rel="shortcut icon" href="path/to/favicon.ico">
4.3 viewport
[建议] 若页面欲对移动设备友好,需指定页面的 viewport。
viewport meta tag 可以设置可视区域的宽度和初始缩放大小,避免在移动设备上出现页面展示不正常。
比如,在页面宽度小于 980px 时,若需 iOS 设备友好,应当设置 viewport 的 width 值来适应你的页面宽度。同时因为不同移动设备分辨率不同,在设置时,应当使用 device-width 和 device-height 变量。
5 图片
- [强制] 禁止 img 的 src 取值为空。延迟加载的图片也要增加默认的 src。(注:src 取值为空,会导致部分浏览器重新加载一次当前页面)
- [建议] 避免为 img 添加不必要的 title 属性。(注:多余的 title 影响看图体验,并且增加了页面尺寸。)
- [建议] 为重要图片添加 alt 属性。(注:可以提高图片加载失败时的用户体验。)
- [建议] 添加 width 和 height 属性,以避免页面抖动。
- [建议] 有下载需求的图片采用 img 标签实现,无下载需求的图片采用 CSS 背景图实现。
6 表单
6.1 控件标题
- [强制] 有文本标题的控件必须使用 label 标签将其与其标题相关联。
示例:
<label><input type="checkbox" name="confirm" value="on"> 我已确认上述条款</label>
6.1 按钮
- [强制] 使用 button 元素时必须指明 type 属性值(注:button 元素的默认 type 为 submit,如果被置于 form 元素中,点击后将导致表单提交。为显示区分其作用方便理解,必须给出 type 属性。)
示例:
<button type="submit">提交</button>
<button type="button">取消</button>