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

本文探讨了JavaScript项目的编码风格,总结了六种流行的编码规范,并提供了一致风格的配置方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

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

代码风格

缩进 

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

 参数和表达式之间的空格 

  • 使用紧凑型风格:Google、NPM、Node.js  
Js代码 复制代码
  1. project.MyClass = function(arg1, arg2) {  
  • 过多地使用空格:Idiomatic, jQuery   
Js代码 复制代码
  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  
Js代码 复制代码
  1. var foo = '';   
  2. var bar = '';   
  • 一次声明多个,在行结束处使用逗号分隔:Idiomatic、jQuery 
Js代码 复制代码
  1. var foo = "",   
  2.   bar = "",   
  3.   quux;   
  • 在行开始处使用逗号:NPM
  • 没有发表意见:Google、Crockford

 大括号 

  • 在同一行使用左大括号:Google、NPM、Node.js、Idiomatic、 jQuery、Crockford 
Js代码 复制代码
  1. function thisIsBlock(){  
NPM指南中指出,只在代码块需要包含下一行时使用大括号,否则不使用。

全局变量 

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

 命名风格

变量命名 

  • 开始的第一个单词小写,之后的所有单词首字母大写:Google、NPM、Node.js、Idiomatic 
Js代码 复制代码
  1. var foo = "";   
  2. var fooName = "";  
  常量命名
  • 使用大写字母:Google、NPM、Node.js 
Js代码 复制代码
  1. var CONS = 'VALUE';   
  • 没有发表意见:jQuery、Idiomatic、Crockford

 函数命名 

  • 开始的第一个单词小写,之后的所有单词首字母大写(驼峰式):Google、NPM、Idiomatic、Node.js(推荐使用长的、具描述性的函数名) 
Js代码 复制代码
  1. function veryLongOperationName   
  2. function short()..  
      关键字形式的函数命名: 
Js代码 复制代码
  1. function isReady()   
  2. function setName()   
  3. function getName()   
  • 没有发表意见:jQuery、Crockford

 阵列命名 

  • 使用复数形式:Idiomatic  
Js代码 复制代码
  1. var documents = [];   
  • 没有发表意见:Google、jQuery、NPM、Node.js、Crockford

 对象和类命名 

  • 使用如下形式:Google、NPM、Node.js 
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代码编辑器将会按照它来统一项目中的所有代码风格。 

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

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

Js代码 复制代码
  1. /* jshint browser:true, jquery:true */   

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

Js代码 复制代码
  1. /*jshint node:true */   

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

Js代码 复制代码
  1. 'use strict';   

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

在提交Git之前自动执行JSHint

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

Js代码 复制代码
  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  

 

内容概要:本文档详细介绍了基于MATLAB实现的多头长短期记忆网络(MH-LSTM)结合Transformer编码器进行多变量时间序列预测的项目实例。项目旨在通过融合MH-LSTM对时序动态的细致学习和Transformer对全局依赖的捕捉,显著提升多变量时间序列预测的精度和稳定性。文档涵盖了从项目背景、目标意义、挑战与解决方案、模型架构及代码示例,到具体的应用领域、部署与应用、未来改进方向等方面的全面内容。项目不仅展示了技术实现细节,还提供了从数据预处理、模型构建与训练到性能评估的全流程指导。 适合人群:具备一定编程基础,特别是熟悉MATLAB和深度学习基础知识的研发人员、数据科学家以及从事时间序列预测研究的专业人士。 使用场景及目标:①深入理解MH-LSTM与Transformer结合的多变量时间序列预测模型原理;②掌握MATLAB环境下复杂神经网络的搭建、训练及优化技巧;③应用于金融风险管理、智能电网负荷预测、气象预报、交通流量预测、工业设备健康监测、医疗数据分析、供应链需求预测等多个实际场景,以提高预测精度和决策质量。 阅读建议:此资源不仅适用于希望深入了解多变量时间序列预测技术的读者,也适合希望通过MATLAB实现复杂深度学习模型的开发者。建议读者在学习过程中结合提供的代码示例进行实践操作,并关注模型训练中的关键步骤和超参数调优策略,以便更好地应用于实际项目中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值