前言
代码规范参考借鉴自各个团队规范,提供肉联帮前端团队规范。
基本规范
命名规范
命名分类

  • camelCase(驼峰式,也叫小驼峰命名,e.g. userInfo
  • PascalCase(帕斯卡命名式,也叫大驼峰命名,e.g. UserInfo
  • kebab-case(短横线连接式,e.g. user-info
  • snake_case(下划线连接式,e.g. user_info

项目命名
全部采用小写方式, 以下划线分隔。 例:snake_case
目录命名
组件目录使用PascalCase,其他目录统一使用kebab-case风格
HTML命名
单数复数使用kebab_case.js风格
CSS命名
统一使用snake_case.css
HTML命名
统一使用snake_case.html
HTML 规范
语法标准

  • 缩进使用 tab(2 个空格);
  • 嵌套的节点应该缩进;
  • 在属性上,使用双引号,不要使用单引号;
  • 属性名全小写,用中划线(-)做分隔符;
  • 要在自动闭合标签结尾处使用斜线;
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <title>Page title</title>
  5. </head>
  6. <body>
  7. <img src="images/image.png" alt="Image" />
  8. <!-- 属性名全小写,用中划线(-)做分隔符 -->
  9. <h1 class="hello-world">Hello, world!</h1>
  10. </body>
  11. </html>

规定字符编码

通过声明一个明确的字符编码,让浏览器轻松、快速的确定适合网页内容的渲染方式,通常指定为’UTF-8’。

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="UTF-8" />
  5. </head>
  6. ...
  7. </html>

减少标签数量

  1. <!-- bad -->
  2. <span class="avatar">
  3. <img src="..." />
  4. </span>
  5. <!-- good -->
  6. <img class="avatar" src="..." />

语义化标签

html 的标签能使用语义化的,尽量使用语义化标签,避免一个页面都是 div 或者 p 标签

  1. <!-- bad -->
  2. <div>
  3. <p></p>
  4. </div>
  5. <!-- good -->
  6. <header></header>
  7. <footer></footer>

CSS规范

缩进

使用 tab 缩进(2 个空格)

  1. .element {
  2. border-radius: 10px;
  3. width: 50px;
  4. height: 50px;
  5. }

分号

每个声明结束都要加分号

  1. .element {
  2. border-radius: 10px;
  3. width: 50px;
  4. height: 50px;
  5. }

注释

注释统一使用 / /

  1. /* 这里是注释 */
  2. .element {
  3. width: 50px;
  4. height: 50px;
  5. }

引号

  • url 的内容要用引号
  • 属性选择器中的属性值需要引号
    1. .element:after {
    2. content: "";
    3. background-image: url("logo.png");
    4. }
    5. li[data-type="single"] {
    6. ...;
    7. }

命名

  • 类名使用小写字母,以中划线分隔
  • id 采用驼峰式命名
    1. /* class */
    2. .element-content {
    3. ...;
    4. }
    5. /* id */
    6. #myDialog {
    7. ...;
    8. }

JavaScript 规范

缩进

使用 tab 缩进(2 个空格)

  1. if (x < y) {
  2. x += 10;
  3. } else {
  4. x += 1;
  5. }

变量命名

  • 变量采用驼峰式命名camelCase
  • 常量使用全大写,用下划线连接
  • 构造函数和Class采用PascalCase ``` var thisIsMyName; var MAX_COUNT = 10; function Person(name) { this.name = name; } Class Person {

}

  1. 变量声明<br />一个函数作用域中所有的变量声明尽量提到函数首部。优先使用块级变量`let` `const`,如无需修改的常量使用`const`<br />单行长度<br />单行长度不得超过 100,超过部分需要换行<br />分号<br />统一要加分号。<br />空格
  2. - 三元运算符'?:'前后
  3. - 逗号后必须要有空格
  4. - 代码块'{'
  5. - 下列关键字前:else, while, catch, finally
  6. - 下列关键字后:if, else, for, while, do, switch, case, try,catch, finally, with, return, typeof
  7. - 单行注释'//'后(若单行注释和代码同行,则'//'前也需要),多行注释'*'
  8. - 对象的属性值前
  9. - for 循环,分号后留有一个空格,前置条件如果有多个,逗号后留一个空格
  10. - 无论是函数声明还是函数表达式,'{'前一定要有空格
  11. - 函数的参数之间
  12. 例:
  13. ```javascript
  14. // not good
  15. var a = {
  16. b : 1
  17. };
  18. // good
  19. var a = {
  20. b: 1
  21. };
  22. // not good
  23. ++x;
  24. y++;
  25. z = x ? 1:2;
  26. // good
  27. ++x;
  28. y++;
  29. z = x ? 1 : 2;
  30. // not good
  31. var a = [ 1, 2 ];
  32. // good
  33. var a = [1, 2];
  34. // good
  35. var doSomething = function(a, b, c) {
  36. // do something
  37. };
  38. // good
  39. doSomething(item);
  40. // not good
  41. for (let i = 0;i < 6;i++) {
  42. x++;
  43. }
  44. // good
  45. for (let i = 0; i < 6; i++) {
  46. x++;
  47. }

空行

  • 变量声明后(当变量声明在代码块的最后一行时,则无需空行)
  • 注释前(当注释在代码块的第一行时,则无需空行)
  • 定义函数前
  • 文件最后保留一个空行
    1. var x = 1;
    2. // 注释前要有空行
    3. if (x >= 1) {
    4. var y = x + 1;
    5. }
    6. function test () {
    7. ...
    8. }

换行

  • 代码块’{‘后和’}’前
  • 变量赋值后 ```javascript // good var a = { b: 1, c: 2 };

x = y ? 1 : 2;

// good if (condition) { … } else { … }

try { … } catch (e) { … } finally { … }

// good function test() { … }

// good var a,foo = 7, b, c, bar = 8;

<a name="6kVL9"></a>
### 注释
**单行注释**

- 注释单独一行的情况下,注释的//后面要跟一个空格
- 注释如果和代码同一行,代码分号结束后,要跟一个空格,注释的//后也要跟一个空格
```javascript
// 调用函数
foo();
var maxCount = 10; // 这是一个变量

多行注释
多行注释使用下面这种形式:

/**
 * 代码注释1
 * 代码注释2
 */

多行注释建议在以下几种情况使用:

  • 难于理解的代码段
  • 可能存在错误的代码段
  • 业务逻辑强相关的代码

    函数注释

    复杂的函数,所有类,都必须进行函数注释,函数注释使用业界统一的规范,方便后续使用 jsdoc 生成文档。最好配置VSCode自动生成模板
    例:
    /**
    * @description 函数描述的 必填
    * @param id {Number} 传入需要获取名称的人物id 参数必填
    * @return {String} 返回的姓名 返回值必填,空为void
    * @author shi 2015/07/21 作者可选
    * @version 1.1.0 可以不写 版本可选
    * @example 示例代码,可选
    */
    function getTaskName(id) {
    let name = "test";
    return name;
    }
    

引号

最外层统一使用单引号,除非字符串嵌套的情况使用双引号。

var y = 'foo',
  z = '<div id="test"></div>';

对象,数组

  • 对象属性名不需要加引号,如对象属性名是中划线命名的需要加引号(eslintrules
  • 对象以缩进的形式书写,不要写在一行(单个属性可以写一行,es6 导入方法时可以使用单行);
  • 数组、对象最后不要有逗号。
    // good
    var a = {
    b: 1,
    c: 2
    };
    

括号

下列关键字后必须有大括号(即使代码块的内容只有一行):if, else, for, while, do, switch, try, catch, finally, with

// not good
if (condition) doSomething();
// good
if (condition) {
  doSomething();
}

undefined

永远不要直接使用 undefined 进行变量判断;
使用 typeof 和字符串’undefined’对变量进行判断。

// not good
if (person === undefined) {
    ...
}
// good
if (typeof person === 'undefined') {
    ...
}

不允许存在多层嵌套的条件判断和循环(最多三层)(重点强调⭐)

条件判断能使用三目运算符和逻辑运算符解决的,就不要使用条件判断,但是谨记不要写太长的三目运算符

// bad
if (x === 10) {
  return 'valid';
} else {
  return 'invalid';
}
// good
return x === 10 ? 'valid' : 'invalid';
// bad
if (!x) {
  if (!y) {
    x = 1;
  } else {
    x = y;
  }
}
// good
x = x || y || 1;