当前流行的JavaScript代码风格指南


Posted in Javascript onSeptember 10, 2014

JavaScript 没有一个权威的编码风格指南,取而代之的是一些流行的编码风格:

Google的JavaScript风格指南(以下简称Google)
http://google-styleguide.googlecode.com/svn/trunk/javascriptguide.xml

NPM编码风格(以下简称NPM)
https://npmjs.org/doc/coding-style.html

Felix的Node.js风格指南(以下简称Node.js)
http://nodeguide.com/style.html

惯用(Idiomatic)的JavaScript(以下简称Idiomatic)
https://github.com/rwldrn/idiomatic.js/

jQuery JavaScript风格指南(以下简称jQuery)
http://contribute.jquery.org/style-guide/js/

Douglas Crockford的JavaScript风格指南(以下简称Crockford),Douglas Crockford是Web开发领域最知名的技术权威之一,ECMA JavaScript 2.0标准化委员会委员
http://javascript.crockford.com/code.html

当然,在JavaScript语法检查器 JSLint 和 JSHint 中也有一些默认的设置选择。问题是,什么才是终极的、让大多数开发者可以遵循的JavaScript编码风格呢?下面让我们从这6个风格指南中找出一些有共识的风格来。

1. 代码风格比较

1.1 缩进

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

1.2 参数和表达式之间的空格

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

project.MyClass = function(arg1, arg2) {

过多地使用空格:Idiomatic, jQuery
for ( i = 0; i < length; i++ ) {

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

1.3 代码行长度

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

1.4 分号

始终使用分号,不依赖于隐式插入:Google、Node.js、Crockford
在某些情况下不要使用expect:NPM
没有发表意见:jQuery、Idiomatic

1.5 注释

遵循JSDoc约定:Google、Idiomatic
没有发表意见:NPM、Node.js、jQuery、Crockford

1.6 引号

推荐单引号:Google、Node.js
双引号:jQuery
没有发表意见:NPM、Idiomatic、Crockford

1.7 变量声明

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

var foo = ”;

var bar = ”;

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

bar = “”,

quux;

在行开始处使用逗号:NPM
没有发表意见:Google、Crockford

1.8 大括号

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

function thisIsBlock(){

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

1.9 全局变量

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

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

2 命名风格

2.1 变量命名

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

var foo = “”;

var fooName = “”;

2.2 常量命名

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

var CONS = ‘VALUE';

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

2.3 函数命名

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

function veryLongOperationName

function short()..

关键字形式的函数命名:
function isReady()

function setName()

function getName()

没有发表意见:jQuery、Crockford

2.4 数组命名

使用复数形式:Idiomatic

var documents = [];

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

2.5 对象和类命名

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

var ThisIsObject = new Date;

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

2.6 其他命名

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

3. 根据上述风格配置 .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 将会运行得更快。

4. 在提交 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
Javascript 相关文章推荐
基于jquery的3d效果实现代码
Mar 23 Javascript
深入浅析javascript立即执行函数
Oct 23 Javascript
javascript中arguments,callee,caller详解
Mar 16 Javascript
jquery.validate[.unobtrusive]和Bootstrap实现tooltip错误提示问题分析
Oct 30 Javascript
gulp加批处理(.bat)实现ng多应用一键自动化构建
Feb 16 Javascript
详解angularjs 关于ui-router分层使用
Jun 12 Javascript
vue的style绑定background-image的方式和其他变量数据的区别详解
Sep 03 Javascript
Bootstrap-table使用footerFormatter做统计列功能
Sep 07 Javascript
在Node.js下运用MQTT协议实现即时通讯及离线推送的方法
Jan 24 Javascript
基于elementUI使用v-model实现经纬度输入的vue组件
May 12 Javascript
vue 页面回退mounted函数不执行的解决方案
Jul 26 Javascript
vue中echarts的用法及与elementui-select的协同绑定操作
Nov 17 Vue.js
在css加载完毕后自动判断页面是否加入css或js文件
Sep 10 #Javascript
JQuery拖动表头边框线调整表格列宽效果代码
Sep 10 #Javascript
jQuery通过点击行来删除HTML表格行的实现示例
Sep 10 #Javascript
javascipt:filter过滤介绍及使用
Sep 10 #Javascript
用javascript将数据导入Excel示例代码
Sep 10 #Javascript
js使用for循环及if语句判断多个一样的name
Sep 09 #Javascript
JQuery实现当鼠标停留在某区域3秒后自动执行
Sep 09 #Javascript
You might like
PHP安全配置
2006/12/06 PHP
php/js获取客户端mac地址的实现代码
2013/07/08 PHP
php版微信返回用户text输入的方法
2016/11/14 PHP
PHP设计模式之工厂方法设计模式实例分析
2018/04/25 PHP
php实现推荐功能的简单实例
2019/09/29 PHP
几个有趣的Javascript Hack
2010/07/24 Javascript
解决3.01版的jquery.form.js中文乱码问题的解决方法
2012/03/08 Javascript
自己使用jquery写的一个无缝滚动的插件
2014/04/30 Javascript
实例解析JS布尔对象的toString()方法和valueOf()方法
2015/10/25 Javascript
实例详解Nodejs 保存 payload 发送过来的文件
2016/01/14 NodeJs
js轮播图代码分享
2016/07/14 Javascript
Angular ng-class详解及实例代码
2016/09/19 Javascript
原生js轮播(仿慕课网)
2017/02/15 Javascript
AngularJS折叠菜单实现方法示例
2017/05/18 Javascript
jquery仿京东商品放大浏览页面
2017/06/06 jQuery
详解plotly.js 绘图库入门使用教程
2018/02/23 Javascript
vue完成项目后,打包成静态文件的方法
2018/09/03 Javascript
[01:35]2014DOTA2西雅图邀请赛 专访狐狸妈青春献给刀塔
2014/07/08 DOTA
[01:34]DOTA2 7.22版本新增神杖效果一览(敏捷英雄篇)
2019/05/28 DOTA
Python3中简单的文件操作及两个简单小实例分享
2017/06/18 Python
Python2随机数列生成器简单实例
2017/09/04 Python
用tensorflow构建线性回归模型的示例代码
2018/03/05 Python
使用pycharm生成代码模板的实例
2018/05/23 Python
python利用Opencv实现人脸识别功能
2019/04/25 Python
详解python函数的闭包问题(内部函数与外部函数详述)
2019/05/17 Python
Python任务自动化工具tox使用教程
2020/03/17 Python
Python利用Xpath选择器爬取京东网商品信息
2020/06/01 Python
Python reversed反转序列并生成可迭代对象
2020/10/22 Python
稀有和绝版书籍:Biblio.com
2017/02/02 全球购物
学习党课思想汇报
2013/12/29 职场文书
开展创先争优活动总结
2014/08/28 职场文书
就业协议书怎么填
2014/09/15 职场文书
英文产品推荐信
2015/03/27 职场文书
辞职信格式范文
2015/05/13 职场文书
对学校的意见和建议
2015/06/04 职场文书
2019个人年度目标制定攻略!
2019/07/12 职场文书