zoukankan      html  css  js  c++  java
  • 你应该知道的已达成共识的JavaScript编码风格约定

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

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

    代码风格

    缩进 

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

     参数和表达式之间的空格 

    • 使用紧凑型风格:Google、NPM、Node.js  
    1. project.MyClass = function(arg1, arg2) {  

     

    • 过多地使用空格:Idiomatic, jQuery   
    1. 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  
    1. var foo = '';  
    2. var bar = '';   

     

    • 一次声明多个,在行结束处使用逗号分隔:Idiomatic、jQuery 
    1. var foo = "",  
    2.   bar = "",  
    3.   quux;   

     

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

     大括号 

     

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

     

    1. function thisIsBlock(){  

     

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

     

    全局变量 

     

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

     

     命名风格

     

    变量命名 

     

    • 开始的第一个单词小写,之后的所有单词首字母大写:Google、NPM、Node.js、Idiomatic 
      1. var foo = "";  
      2. var fooName = "";  

     

    常量命名
     

     

    • 使用大写字母:Google、NPM、Node.js 
      1. var CONS = 'VALUE';   

     

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

     

     函数命名 

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

     

    1. function veryLongOperationName  
    2. function short()..  

    关键字形式的函数命名: 

    1. function isReady()  
    2. function setName()  
    3. function getName()  
    • 没有发表意见:jQuery、Crockford

     数组命名 

    使用复数形式:Idiomatic  

    1. var documents = [];   
    • 没有发表意见:Google、jQuery、NPM、Node.js、Crockford

     对象和类命名 

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

     

    1. 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代码编辑器将会按照它来统一项目中的所有代码风格。 

     

    1. {  
    2.   "camelcase" : true,  
    3.   "indent": 2,  
    4.   "undef"true,  
    5.   "quotmark": single,  
    6.   "maxlen": 80,  
    7.   "trailing"true,  
    8.   "curly"true  
    9. }   

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

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

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

    1. /*jshint node:true */   

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

    1. 'use strict';   

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

    在提交Git之前自动执行JSHint

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

    1. #!/bin/bash  
    2. # Pre-commit Git hook to run JSHint on JavaScript files.  
    3. #  
    4. # If you absolutely must commit without testing,  
    5. # use: git commit --no-verify  
    6.    
    7. filenames=($(git diff --cached --name-only HEAD))  
    8.    
    9. which jshint &> /dev/null  
    10. if [ $? -ne 0 ];  
    11. then  
    12.   echo "error: jshint not found"  
    13.   echo "install with: sudo npm install -g jshint"  
    14.   exit 1  
    15. fi  
    16.    
    17. for i in "${filenames[@]}"  
    18. do  
    19.     if [[ $i =~ .js$ ]];  
    20.     then  
    21.         echo jshint $i  
    22.         jshint $i  
    23.         if [ $? -ne 0 ];  
    24.         then  
    25.             exit 1  
    26.         fi  
    27.     fi  
    28. done  
     最后祝大家编码愉快!

    英文原文:JavaScript, the winning style

  • 相关阅读:
    Python学习第106天(Django的静态文件static、url分组)
    Python学习第105天(Django初步实现)
    Python学习第104天(Django前传web框架)
    Python学习第103天(http协议)
    Python学习第102(数据库进阶)
    Python学习第101天(mysql索引)
    Python学习第100天(多表查询:连接查询、复合查询、子查询)
    Python学习第99天(子网划分)
    java强制转换+自动转换
    WINDOWS快捷键
  • 原文地址:https://www.cnblogs.com/helenR/p/javascript_memory_rule.html
Copyright © 2011-2022 走看看