让前端飞Web前端之路前端Vue专辑

制定自己团队的前端开发规范

2019-07-18  本文已影响16人  石燕平_Leo

篇幅可能会比较长,但是我感觉有一套规范对于一个团队其实还是很重要的,这样在维护起来也会很方便,代码规范参考自:腾讯alloyteam团队,希望大家可以跟着看一遍,各取所需。后续还会更新一个eslint的规范和vscode编辑器格式化的插件Prettier的规范。

命名规范

项目命名

全部采用小写方式, 以下划线分隔。
例:my_project_name

目录命名

参照项目命名规则;

有复数结构时,要采用复数命名法。

例:scriptsstylesimagesdata_models

vue的项目中,components下的组件目录名,使用大驼峰命令

例:LeftBar

JS文件命名

参照项目命名规则。

例:account_model.js

CSS, SCSS文件命名

参照项目命名规则。

例:retina_sprites.css

HTML文件命名

参照项目命名规则。

例:error_log.html

HTML规范

语法:

<!DOCTYPE html>
<html>
    <head>
        <title>Page title</title>
    </head>
    <body>
        <img src="images/company_logo.png" alt="Company">
        
        <!-- 属性名全小写,用中划线(-)做分隔符 -->
        <h1 class="hello-world">Hello, world!</h1>
    </body>
</html>

标准模式

在开头规定doctype,来启动标准模式,doctype要大写。

<!DOCTYPE html>
<html>
    ...
</html>

规定字符编码

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

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
    </head>
    ...
</html>

IE兼容模式

用meta标签指定页面应该使用什么版本的IE来渲染。

<!DOCTYPE html>
<html>
    <head>
        <meta http-equiv="X-UA-Compatible" content="IE=Edge">
    </head>
    ...
</html>

减少标签数量

在编写HTML代码时,需要尽量避免多余的父节点;

<!-- bad -->
<span class="avatar">
    <img src="...">
</span>

<!-- good -->
<img class="avatar" src="...">

语义化标签

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

<!-- bad -->
<div>
    <p></p>
</div>

<!-- good -->
<header></header>
<footer></footer>

CSS 规范

缩进

使用tab缩进(4个空格)

.element {
    border-radius: 10px;
    width: 50px;
    height: 50px;
}

分号

每个声明结束都要加分号

.element {
    border-radius: 10px;
    width: 50px;
    height: 50px;
}

注释

注释统一使用 /* */

.element {
    /* border-radius: 10px; */
    width: 50px;
    height: 50px;
}

引号

.element:after {
    content: "";
    background-image: url("logo.png");
}

li[data-type="single"] {
    ...
}

命名

/* class */
.element-content {
    ...
}

/* id */
#myDialog {
    ...
}

/* 变量 */
$colorBlack: #000;

/* 混合 */
@mixin centerBlock {
    ...
}

JavaScript 规范

缩进

使用tab缩进(4个空格)

if (x < y) {
    x += 10;
} else {
    x += 1;
}

变量命名

var thisIsMyName;

var goodID;

var reportURL;

var AndroidVersion;

var iOSVersion;

var MAX_COUNT = 10;

function Person(name) {
    this.name = name;
}

// not good
var body = $('body');

// good
var $body = $('body');

变量声明

一个函数作用域中所有的变量声明尽量提到函数首部,用一个var声明,不允许出现两个连续的var声明。如果可以使用let和const的,要使用let和const。

function doSomethingWithItems(items) {
    // use one var
    let value = 10,
        result = value + 10,
        i,
        len;

    for (i = 0, len = items.length; i < len; i++) {
        result += 10;
    }
}

单行长度

不要超过80,但如果编辑器开启word wrap可以不考虑单行长度。

分号

统一要加分号。

空格

以下几种情况不用写空格:

以下几种情况一定要写空格:

例:

// not good
var a = {
    b :1
};

// good
var a = {
    b: 1
};

// not good
++ x;
y ++;
z = x?1:2;

// good
++x;
y++;
z = x ? 1 : 2;

// not good
var a = [ 1, 2 ];

// good
var a = [1, 2];

// not good
var a = ( 1+2 )*3;

// good
var a = (1 + 2) * 3;

// good
var doSomething = function(a, b, c) {
    // do something
};

// good
doSomething(item);

// not good
for(i=0;i<6;i++){
    x++;
}

// good
for (i = 0; i < 6; i++) {
    x++;
}

空行

以下几种情况一定要有空行

var x = 1;

// 注释前要有空行
if (x >= 1) {
    var y = x + 1;
}

换行

换行的地方,行末必须有','或者运算符;

以下几种情况不需要换行:

以下几种情况需要换行:

// not good
var a = {
    b: 1
    , c: 2
};

x = y
    ? 1 : 2;

// good
var a = {
    b: 1,
    c: 2
};

x = y ? 1 : 2;

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

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

// not good
function test()
{
    ...
}

// good
function test() {
    ...
}

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

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

注释

单行注释

例:

// 调用函数
foo()

var maxCount= 10; // 这是一个变量

多行注释

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

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

建议在以下几种情况使用:

函数注释

复杂的函数,所有类,都必须进行函数注释,函数注释使用业界统一的规范,方便后续使用jsdoc生成文档。

例:

/**
 * 获取任务的名称
 * @param id {Number} 传入需要获取名称的人物id
 * @return {String} 返回的姓名
 * @author shi 2015/07/21 可以不写
 * @version 1.1.0 可以不写
 * @example 示例代码,可以不写
*/
function getTaskName(id) {
    let name = 'test';
    return name;
}

引号

最外层统一使用单引号

// not good
var x = "test";

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

对象,数组

// not good
var a = {
    'b': 1
};

var a = {b: 1};

var a = {
    b: 1,
    c: 2,
};

// 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

简单解释一下逻辑运算符,逻辑运算符主要有两种,一个是 || 逻辑或,一个是 && 逻辑与。

var x = 1;
console.log(x || 2); // 1

var y = 0;
console.log(y || 2); // 2
var x = 1;
console.log(x && 2); // 2

var y = 0;
console.log(y && 2); // 0

其他ESlint

// good
for (key in obj) {
    if (obj.hasOwnProperty(key)) {
        // be sure that obj[key] belongs to the object and was not inherited
        console.log(obj[key]);
    }
}

// not good
Array.prototype.count = function(value) {
    return 4;
};

// not good
function test() {
    console.log(x);

    var x = 1;
}

// not good
new Person();

// good
var person = new Person();

// not good
delete(obj.attr);

// good
delete obj.attr;

// not good
var a = [1, , , 2, 3];

// not good
var nums = [];

// not good
for (var i = 0; i < 10; i++) {
    (function(i) {
        nums[i] = function(j) {
            return i + j;
        };
    }(i));
}

其他

// not good
function Person() {
    // not good
    var me = this;

    // good
    var _this = this;

    // good
    var that = this;

    // good
    var self = this;
}

if (condition) {

}

阅读完后两部曲

  1. 喜欢的小伙伴点个赞吧,感觉对身边人有帮助的,麻烦动动手指,分享一下。非常感谢各位花时间阅读完,同时很感谢各位的点赞和分享。
  2. 希望各位关注一下我的公众号吧,新的文章第一时间发到公众号,公众号主要发一些个人随笔、读书笔记、还有一些技术热点和实时热点,并且还有非常吸引人的我个人自费抽奖活动哦~
image
上一篇下一篇

猜你喜欢

热点阅读