一些达成共识的 JavaScript 编码风格约定

发布于 2019-04-15 09:52:12 字数 4767 浏览 1945 评论 0

如果你的代码易于阅读,那么代码中 bug 也将会很少,因为一些 bug 可以很容被调试,并且,其他开发者参与你项目时的门槛也会比较低。因此如果项目中有多人参与,采取一个有共识的编码风格约定非常有必要。与其他一些语言相比(比如Python示例),JavaScript 没有一个权威的编码风格指南,取而代之的是一些流行的编码风格:

当然在 JavaScript 语法检查器 JSLint 和 JSHint 中也有一些默认的设置选择。问题是什么才是终极的、让大多数开发者可以遵循的 JavaScript 编码风格呢?

下面让我们从这6个风格指南中找出一些有共识的风格来。

代码风格

缩进

两个空格,无需更长的缩进,无需 Tab 缩进:Google、NPM、Node.js、Idiomatic

Tab 缩进:jQuery

4个空格:Crockford

参数和表达式之间的空格

使用紧凑型风格:Google、NPM、Node.js

project.MyClass = function(arg1, arg2) {

过多地使用空格:Idiomatic、jQuery

for ( i = 0; i < length; i++ ) {

没有发表意见:Crockford

大部分指南中,都提醒开发者不要在语句结尾处有任何的空格。

代码行长度

最多80个字符:Google、NPM、Node.js、Crockford(当在代码块中,除了2个空格外的其他缩进允许将函数参数与首个函数参数的位置对齐。另一种选择是当自动换行时使用4个空格缩进,而不是2个。)
没有发表意见:jQuery、Idiomatic

分号

始终使用分号,不依赖于隐式插入:Google、Node.js、Crockford

在某些情况下不要使用 expect:NPM

没有发表意见:jQuery、Idiomatic

注释

遵循 JSDoc 约定:Google、Idiomatic

没有发表意见:NPM、Node.js、jQuery、Crockford

引号

推荐单引号:Google、Node.js

双引号:jQuery

没有发表意见:NPM、Idiomatic、Crockford

变量声明

一次声明一个,不使用逗号:Node.js

var foo = '';
var bar = '';

一次声明多个,在行结束处使用逗号分隔:Idiomatic、jQuery

var foo = "",
bar = "",
quux;

在行开始处使用逗号:NPM

没有发表意见:Google、Crockford

大括号

在同一行使用左大括号:Google、NPM、Node.js、Idiomatic、 jQuery、Crockford

function thisIsBlock(){

NPM 指南中指出,只在代码块需要包含下一行时使用大括号,否则不使用。

全局变量

不要使用全局变量:Google、Crockford(谷歌表示,全局变量命名冲突难以调试,并可能在两个项目进行正整合时出现一些棘手的问题。为了便于共享公用的 JavaScript 代码,需要制定公约来避免冲突发生。Crockford认为不应该使用隐式全局变量。)

没有发表意见:Idiomatic、jQuery、NPM、Node.js

命名风格

变量命名

开始的第一个单词小写,之后的所有单词首字母大写:Google、NPM、Node.js、Idiomatic

var foo = "";  
var fooName = "";

常量命名

使用大写字母:Google、NPM、Node.js

var CONS = 'VALUE';

没有发表意见:jQuery、Idiomatic、Crockford

函数命名

开始的第一个单词小写,之后的所有单词首字母大写(驼峰式):Google、NPM、Idiomatic、Node.js(推荐使用长的、具描述性的函数名)

function veryLongOperationName  
function short()..

关键字形式的函数命名:

function isReady()  
function setName()  
function getName()

没有发表意见:jQuery、Crockford

数组命名

使用复数形式:Idiomatic

var documents = [];

没有发表意见:Google、jQuery、NPM、Node.js、Crockford

对象和类命名

使用如下形式:Google、NPM、Node.js

var ThisIsObject = new Date;

没有发表意见:jQuery、Idiomatic、Crockford

其他命名

针对长文件名和配置键使用 all-lower-hyphen-css-case 形式:NPM

根据上述风格来配置 .jshintrc 文件

JSHint(http://www.jshint.com/)是一个JavaScript语法和风格检查工具,你可以用它来提醒代码风格相关的问题。它可以很好地被集成到许多常用的编辑器中,是统一团队编码风格的一个很好的工具。

你可以通过JSHint文档查看可用的选项:http://www.jshint.com/docs/#options

下面根据本文上面每个分类下的第一种风格来创建一个 .jshintrc 文件。你可以将它放到项目中根目录中,JSHint-avare 代码编辑器将会按照它来统一项目中的所有代码风格。

{  
  "camelcase" : true,  
  "indent": 2,  
  "undef": true,  
  "quotmark": single,  
  "maxlen": 80,  
  "trailing": true,  
  "curly": true  
}

此外你应该将下面的头添加到你的 JavaScript 文件中。

/* jshint browser:true, jquery:true */

在 Node.js 文件中你应该添加:

/*jshint node:true */

还可以在各种 JavaScript 文件中添加下面的声明:

'use strict';

这将影响 JSHint 和你的 JavaScript 引擎,可能不那么兼容,但是 JavaScript 将会运行得更快。

在提交Git之前自动执行JSHint

如果你想确保所有的 JS 代码与 .jshintrc 中定义的风格保持一致,你可以将下面的内容添加到你的 .git/hooks/pre-commit 文件中,当你试图提交任何新修改的文件到项目时会自动执行风格检查。

#!/bin/bash
# Pre-commit Git hook to run JSHint on JavaScript files.  
#  
# If you absolutely must commit without testing,  
# use: git commit --no-verify  

filenames=($(git diff --cached --name-only HEAD))  

which jshint &> /dev/null  
if [ $? -ne 0 ];  
then  
  echo "error: jshint not found"  
  echo "install with: sudo npm install -g jshint"  
  exit 1  
fi  
   
for i in "${filenames[@]}"  
do  
    if [[ $i =~ \.js$ ]];  
    then  
        echo jshint $i  
        jshint $i  
        if [ $? -ne 0 ];  
        then  
            exit 1  
        fi  
    fi  
done

最后祝大家编码愉快。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

JSmiles

生命进入颠沛而奔忙的本质状态,并将以不断告别和相遇的陈旧方式继续下去。

文章
评论
84963 人气
更多

推荐作者

夢野间

文章 0 评论 0

doggiejohn

文章 0 评论 0

就此别过

文章 0 评论 0

初见终念

文章 0 评论 0

qq_rvKjBH

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文