首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >制定自己团队的前端开发规范

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

作者头像
用户1462769
发布于 2019-08-09 11:45:14
发布于 2019-08-09 11:45:14
1K00
代码可运行
举报
文章被收录于专栏:全栈者全栈者
运行总次数:0
代码可运行
篇幅可能会比较长,但是我感觉有一套规范对于一个团队其实还是很重要的,这样在维护起来也会很方便,如果接下来的规范感觉对你们团队有帮助,希望可以在团队中进行实践或者推荐给你的leader,代码规范参考自:腾讯alloyteam团队,希望大家可以跟着看一遍,各取所需。

后续的文章我也补充齐全了,一共有两篇,都是实战篇,一篇是制定自己团队的前端开发规范之 eslint,另外一篇是手摸手带你实践标准的前端开发规范,希望大家可以去看一下,然后把这套规范实践起来,让自己的开发存在更少的bug。

如果可以的话,实践过程中有用的不舒服的,麻烦给我进行反馈,这样才能知道这套规则适不适合大部分人去用,根据大家的意见,取其精华去其糟粕让这套规范变得更实用。

命名规范

项目命名

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

目录命名

参照项目命名规则;

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

例:scriptsstylesimagesdata_models

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

例:LeftBar

JS文件命名

参照项目命名规则。

例:account_model.js

CSS, SCSS文件命名

参照项目命名规则。

例:retina_sprites.css

HTML文件命名

参照项目命名规则。

例:error_log.html

HTML规范

语法:

  • 缩进使用tab(2个空格);
  • 嵌套的节点应该缩进;
  • 在属性上,使用双引号,不要使用单引号;
  • 属性名全小写,用中划线(-)做分隔符;
  • 要在自动闭合标签结尾处使用斜线,为了适应 react(通过留言区反馈进行修改);
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<!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要大写。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<!DOCTYPE html>
<html>
    ...
</html>

规定字符编码

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
    </head>
    ...
</html>

IE兼容模式

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<!DOCTYPE html>
<html>
    <head>
        <meta http-equiv="X-UA-Compatible" content="IE=Edge">
    </head>
    ...
</html>

减少标签数量

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<!-- bad -->
<span class="avatar">
    <img src="...">
</span>

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

语义化标签

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<!-- bad -->
<div>
    <p></p>
</div>

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

CSS 规范

缩进

使用tab缩进(2个空格)

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
.element {
    border-radius: 10px;
    width: 50px;
    height: 50px;
}

分号

每个声明结束都要加分号

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
.element {
    border-radius: 10px;
    width: 50px;
    height: 50px;
}

注释

注释统一使用 /* */

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
.element {
    /* border-radius: 10px; */
    width: 50px;
    height: 50px;
}

引号

  • url的内容要用引号
  • 属性选择器中的属性值需要引号
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
.element:after {
    content: "";
    background-image: url("logo.png");
}

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

命名

  • 类名使用小写字母,以中划线分隔
  • id采用驼峰式命名
  • scss中的变量、函数、混合、placeholder采用驼峰式命名
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
/* class */
.element-content {
    ...
}

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

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

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

JavaScript 规范

缩进

使用tab缩进(2个空格)

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
if (x < y) {
    x += 10;
} else {
    x += 1;
}

变量命名

  • 标准变量采用驼峰式命名
  • 'ID'在变量名中全大写
  • 'URL'在变量名中全大写
  • 'Android'在变量名中大写第一个字母
  • 'iOS'在变量名中小写第一个,大写后两个字母
  • 常量全大写,用下划线连接
  • 构造函数,大写第一个字母
  • jquery对象必须以'$'开头命名
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
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。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
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可以不考虑单行长度。

分号

统一要加分号。

空格

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

  • 对象的属性名后
  • 函数调用括号前
  • 无论是函数声明还是函数表达式,'('前不要空格
  • 数组的'['后和']'前
  • 对象的'{'后和'}'前
  • 运算符'('后和')'前

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

  • 三元运算符'?:'前后
  • 代码块'{'前
  • 下列关键字前:else, while, catch, finally
  • 下列关键字后:if, else, for, while, do, switch, case, try,catch, finally, with, return, typeof
  • 单行注释'//'后(若单行注释和代码同行,则'//'前也需要),多行注释'*'后
  • 对象的属性值前
  • for循环,分号后留有一个空格,前置条件如果有多个,逗号后留一个空格
  • 无论是函数声明还是函数表达式,'{'前一定要有空格
  • 函数的参数之间

例:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// 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++;
}

空行

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

  • 变量声明后(当变量声明在代码块的最后一行时,则无需空行)
  • 注释前(当注释在代码块的第一行时,则无需空行)
  • 文件最后保留一个空行
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
var x = 1;

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

换行

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

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

  • 下列关键字后:else, catch, finally
  • 代码块'{'前

以下几种情况需要换行:

  • 代码块'{'后和'}'前
  • 变量赋值后
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// 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;

注释

单行注释
  • 注释单独一行的情况下,注释的//后面要跟一个空格
  • 注释如果和代码同一行,代码分号结束后,要跟一个空格,注释的//后也要跟一个空格

例:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// 调用函数
foo()

var maxCount= 10; // 这是一个变量
多行注释

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
/**
 * 代码注释1
 * 代码注释2
 */

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

  • 难于理解的代码段
  • 可能存在错误的代码段
  • 浏览器特殊的HACK代码
  • 业务逻辑强相关的代码
函数注释

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

例:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
/**
 * 获取任务的名称
 * @param id {Number} 传入需要获取名称的人物id
 * @return {String} 返回的姓名
 * @author shi 2015/07/21 可以不写
 * @version 1.1.0 可以不写
 * @example 示例代码,可以不写
*/
function getTaskName(id) {
    let name = 'test';
    return name;
}

引号

最外层统一使用单引号

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// not good
var x = "test";

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

对象,数组

  • 对象属性名不需要加引号;
  • 对象以缩进的形式书写,不要写在一行;
  • 数组、对象最后不要有逗号。
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// 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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// not good
if (condition)
    doSomething();

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

undefined

永远不要直接使用undefined进行变量判断;

使用typeof和字符串'undefined'对变量进行判断。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// not good
if (person === undefined) {
    ...
}

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

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

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

例:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// 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

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

  • 逻辑或 ||:当前一个为真时,返回前一个值,前一个为假时返回后一个值。
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
var x = 1;
console.log(x || 2); // 1

var y = 0;
console.log(y || 2); // 2
  • 逻辑与 &&:当前一个为真时,返回后一个值,前一个为假时返回前一个值。
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
var x = 1;
console.log(x && 2); // 2

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

其他ESlint

  • for-in里一定要有hasOwnProperty的判断;
  • 用'===', '!=='代替'==', '!=',null 除外;
  • 不要在内置对象的原型上添加方法,如Array, Date;
  • 变量不要先使用后声明;
  • 不要在一句代码中单单使用构造函数,记得将其赋值给某个变量;
  • 不要在同个作用域下声明同名变量;
  • 不要在一些不需要的地方加括号,例:delete(a.b);
  • 不要使用未声明的变量;
  • debugger不要出现在提交的代码里;
  • 数组中不要存在空元素;
  • 不要在循环内部声明函数;
  • 不要像这样使用构造函数;
  • 不要声明了变量却不使用;
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// 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));
}

其他

  • 换行符统一用'LF';
  • 对上下文this的引用只能使用'_this', 'that', 'self'其中一个来命名;
  • 行尾不要有空白字符;
  • 不允许有空的代码块。
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// not good
function Person() {
    // not good
    var me = this;

    // good
    var _this = this;

    // good
    var that = this;

    // good
    var self = this;
}

if (condition) {

}

这一套规范我用 vuepress 做了一个网站进行存档,欢迎大家查看。https://www.shiyanping.top/coderule,主要依附 github page 进行部署,也欢迎大家 star 我的 git 项目 https://github.com/Shiyanping/coderule。

相关链接

  • 制定自己团队的前端开发规范之 eslint
  • 手摸手带你实践标准的前端开发规范

阅读完后两部曲

非常感谢各位花时间阅读完,衷心希望各位小伙伴可以花少量的时间帮忙做两件事: 动动你的手指,帮忙点个 star 吧,你的点赞是对我最大的动力。

  • 希望各位关注一下我的公众号,新的文章第一时间发到公众号,公众号主要发一些个人随笔、读书笔记、还有一些技术热点和实时热点~
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-07-31,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 全栈者 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
微信小程序函数处理之保姆级讲解
在使用Page()构造器注册页面时,需要使用生命周期函数,包括onLoad()页面加载时生命周期函数、onShow()页面显示时生命周期函数、onReady()页面初次渲染完成时生命周期函数、onHide()页面隐藏生命周期函数和onUnload()页面卸载生命周期函数。
淼学派对
2022/11/20
1.1K0
微信小程序函数处理之保姆级讲解
【愚公系列】2022年02月 微信小程序-页面生命周期
注册小程序中的一个页面。接受一个 Object 类型参数,其指定页面的初始数据、生命周期回调、事件处理函数等。
愚公搬代码
2022/12/01
5990
微信小程序入门文档下载_小程序开发教程全集免费
最新一版的微信开发者工具,把微信公众号的调试开发工作也集成了进去,可以更换开发模式。
全栈程序员站长
2022/09/20
11.5K0
微信小程序入门文档下载_小程序开发教程全集免费
详解 | 小程序页面间如何进行传递数据
工作中我们经常会遇到B页面需要A页面内的部分或全部数据;C页面内的一个函数执行完之后需要改变B页面内的显示样式;也或者是A和B两个页面用到了同样的网络数据,在其中一个页面做出修改后另一个页面也要随之改变以保证回传服务器时数据的准确性,等等诸如此类的页面间数据传递的问题。
极乐君
2020/11/30
12K0
小程序页面事件与wxs脚本
在使用 组件跳转到指定的 tabBar 页面时,需要指定 url 属性和 open-type 属性,其中:
timerring
2023/06/10
6360
小程序页面事件与wxs脚本
二、小程序框架
小程序开发框架的目标是通过尽可能简单、高效的方式让开发者可以在微信中开发具有原生 APP 体验的服务。
天蝎座的程序媛
2023/10/17
4460
二、小程序框架
小程序百问百答
this对象在程序调用时,如点击事件中会随时改变,而var that=this之后,that没重新赋值之前仍然是指向当时的this,这样就不会出现找不到原来的对象而导致报错
用户10175992
2022/11/15
7780
小程序百问百答
15个高频微信小程序面试题
kRjT-hhuhism9497041.jpg 微信小程序面试题 1. 小程序有几个文件? WXML: 微信自己定义的一套组件 WXSS : 用于描述 WXML 的组件样式 js : 逻辑处理 json : 小程序页面配置 2.小程序怎么跟随事件传值 在 页面标签上通过 绑定 dataset-key = value , 然后绑定点击通过e.currentTarget.dataset.key 来获取标签上绑定的值。 <button bindtap="get" data-name=
程序员海军
2021/01/17
7.2K0
15个高频微信小程序面试题
小程序组件/页面通信
通过在 A 组件在使用 navigateTo Api 跳转时,通过events属性注册事件,然后在 success 成功响应里 向 目标组件触发事件,最后在跳转的目标组件B 中 通过 eventChannel.on 来监听对应的事件即可。
程序员海军
2023/11/13
9530
小程序页面管理与跳转
原文链接:https://godbasin.github.io/2018/09/08/wxapp-page-and-navigate/
李成熙heyli
2018/11/14
3K0
小程序页面管理与跳转
【查缺补漏】 15个高频微信小程序面试题
微信小程序面试题 1. 小程序有几个文件? WXML: 微信自己定义的一套组件 WXSS : 用于描述 WXML 的组件样式 js : 逻辑处理 json : 小程序页面配置 2.小程序怎么跟随事件传值 在 页面标签上通过 绑定 data-key = value , 然后绑定点击通过e.currentTarget.dataset.key 来获取标签上绑定的值。 <button bindtap="get" data-name="测试"> 拿到传值</button> get(e){
程序员海军
2022/02/15
2K0
微信小程序——轮播图、组件传值、下拉刷新、导航 实战开发
滑块视图容器。其中只可放置swiper-item组件,否则会导致未定义的行为。 属性表如下
wsuo
2020/09/22
1.7K0
开发一个微信小程序(2):编写博客园随笔列表
首先我们需要拿到个人博客园的 access_token,这里我希望不要频繁调用这个接口,当进入小程序时调用一次就够了
冰霜
2022/06/06
1.6K3
小程序开发知识必备-自定义组件
在 component 文件目录下,创建一个 select 文件夹,随后 select 文件夹下手动创建:select.js、select.json、select.wxml、select.wxss 四个文件。
leader755
2022/03/09
1.5K0
小程序开发知识必备-自定义组件
【微信小程序+Python后台从0到1实战开发】02微信小程序基础事件及数据获取
day02 微信小程序 1. 跳转 1.1 对标签绑定点击事件 <view bindtap="clickMe" data-nid="123" data-name="SD" >点我跳转</view> Page({ ... /** * 点击绑定的事件 */ clickMe:function(e){ var nid = e.currentTarget.dataset.nid; console.log(nid); } }) 1.2 页面跳转 wx.navigateTo({
天道Vax的时间宝藏
2021/08/11
1.2K0
小程序的生命周期【小程序专题8】
页面加载时,data 将会以JSON字符串的形式由逻辑层传至渲染层,因此data中的数据必须是可以转成JSON的类型:字符串,数字,布尔值,对象,数组。
徐建国
2021/12/08
7840
小程序的生命周期【小程序专题8】
【零基础微信小程序入门开发三】小程序框架一
上几节我们学到了小程序的一些基本功能,以及小程序的工具环境配置,大家学习可以顺着系列文章目录来进行查看,如果你有一定基础可以自己选择跳过章节,本节我们在上节的基础上继续讲解小程序的框架
德宏大魔王
2023/08/08
2700
【零基础微信小程序入门开发三】小程序框架一
小程序 | 15-页面跳转
实现界面跳转有两种方式:通过 navigator 组件 和 通过 wx 的 api 跳转
CnPeng
2021/05/17
9570
小程序 | 15-页面跳转
小程序API之路由详解
小程序API之路由详解 路由 wx.switchTab wx.switchTab(Object object)跳转到 tabBar 页面,并关闭其他所有非 tabBar 页面 参数 属性 类型 默认值 必填 说明 url string 是 success function 否 fail function 否 complete function 否 示例代码 { "tabBar": { "list": [{ "pagePath": "index",
前端老鸟
2019/07/31
1.4K0
全解小程序猜数字游戏 04《 程序员变现指南之 微信&QQ 小程序 真的零基础开发宝典》
由于小程序开发需要一定的基础,这些基础需要提前掌握,本教程只对小程序开发进行零基础说明。
1_bit
2022/01/06
9350
全解小程序猜数字游戏 04《 程序员变现指南之 微信&QQ 小程序 真的零基础开发宝典》
推荐阅读
相关推荐
微信小程序函数处理之保姆级讲解
更多 >
LV.1
这个人很懒,什么都没有留下~
目录
  • 命名规范
    • 项目命名
    • 目录命名
    • JS文件命名
    • CSS, SCSS文件命名
    • HTML文件命名
  • HTML规范
    • 语法:
    • 标准模式
    • 规定字符编码
    • IE兼容模式
    • 减少标签数量
    • 语义化标签
  • CSS 规范
    • 缩进
    • 分号
    • 注释
    • 引号
    • 命名
  • JavaScript 规范
    • 缩进
    • 变量命名
    • 变量声明
    • 单行长度
    • 分号
    • 空格
    • 空行
    • 换行
    • 注释
      • 单行注释
      • 多行注释
      • 函数注释
    • 引号
    • 对象,数组
    • 括号
    • undefined
    • 不允许存在多层嵌套的条件判断和循环(最多三层)
    • 其他ESlint
    • 其他
  • 相关链接
  • 阅读完后两部曲
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档