我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Node.js如何自动审核团队的代码

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Node.js如何自动审核团队的代码

前言

在团队开发中,无论是写前端(js,css,html) ,还是后端 ,我们常常需要解决一个问题:如何统一团队代码风格。 这篇文章主要是使用pre-git , eslint , js-beautify 实现代码风格控制。

下面分别介绍这三个工具和使用方式:

pre-git

该工具能实现git hook的功能,在git的流程中插入一些自定义行为,例如commit之前执行代码检测,如果不通过则报错。

eslint

代码格式审核工具,可以随意组合配置各种风格,用于组成团队的代码统一规范。

js-beautiful

js代码整理、美化工具。

然后这三个工具互相配合就形成了以下效果:

1.项目组长定义好eslint的代码规范。

2.使用pre-git在commit之前运行eslint代码监测和js-beautiful代码美化

3.如果通过则自动"git add ." ,最后允许push。

实现

一:npm安装上述工具

$ npm install eslint js-beautify pre-git --save-dev

二:工具的配置

在根目录新建.eslintrc.json文件,并且把规范配置好,一下给一个精简版:

注意:如需更多检测,请到eslint官网查看


{
  "rules": {
    "comma-dangle": ["error", "never"],
    "arrow-body-style": ["warn", "always"],
    "no-const-assign": ["error"]
    },
  "parserOptions": {
    "ecmaVersion": 6
  }
}

因测试,bash 中使用js-beautiful递归多层文件的时候总出现错误,所以由一脚本来进行代码美化:

beatufyjs.js


const fs = require( 'fs' );
const path = require( 'path' );
const child_process = require( 'child_process' );

for( let arg of process.argv.splice( 2 ) ) {
  let pathName = path.join( process.cwd(),arg );
  if( isFile( path.join( process.cwd(),arg ) ) ) {
    child_process.exec( `./node_modules/js-beautify/js/bin/js-beautify.js -P -E -j -a ${pathName} -r` , function( error, msg, stderr ) {
      console.log( msg.replace('\\n','') );
    } );
  } else {
    read_dir( pathName );
  }
}

function read_dir( dir ){
  let files = fs.readdirSync( dir );
  for( let file of files ) {
    let pathName = path.join( dir,file );
    if( isFile( pathName ) ) {
      child_process.exec( `./node_modules/js-beautify/js/bin/js-beautify.js -P -E -j -a ${pathName} -r` , function( error, msg, stderr ) {
        console.log( msg.replace( '\\n','') );
      } );
    } else {
      read_dir( pathName );
    }
  }
}

function isFile( path ){ 
  return exists( path ) && fs.statSync( path ).isFile(); 
} 

function exists( path ){ 
   return fs.existsSync( path ) || path.existsSync( path ); 
} 

三:使用上述工具

在package.json文件中配置:


{
 "name": "demo",
 "version": "1.0.0",
 "description": "",
 "main": "index.js",
 "scripts": {
  "lint": "./node_modules/.bin/eslint routes runtime utils libs --quiet",
  "lint-fix": "./node_modules/.bin/eslint routes runtime utils libs --quiet --fix",
  "js-beautify": "node --harmony --use_strict ./bin/beatufyjs.js libs middlewares index.js "
 },
 "author": "kelvv",
 "license": "ISC",
 "config": {
  "pre-git": {
   "commit-msg": "",
   "pre-commit": [
    "npm run lint-fix",
    "npm run js-beautify",
    "git add ."
   ],
   "pre-push": [],
   "post-commit": [],
   "post-checkout": [],
   "post-merge": []
  }
 },
 "devDependencies": {
  "eslint": "^2.12.0",
  "js-beautify": "^1.6.3",
  "pre-git": "^3.9.1"
 }
}

此时当你修改其中一个文件,然后"git add && git commit -m 'msg' "的时候,pre-commit中的三条命令就会执行,如果中途有错就会停止提交,修改完毕后再继续提交。

有一点需要注意的是,有的格式问题不足以报错的话,改方法会自动修改优化代码,并且自动添加修改,最后一步,执行:git push即可!可以结合单元测试,更佳

总结

以上就是为大家整理的如何用Node.js自动审核团队的代码的全部内容,有需要的可以进行参考学习。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Node.js如何自动审核团队的代码

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Node.js如何自动审核团队的代码

前言 在团队开发中,无论是写前端(js,css,html) ,还是后端 ,我们常常需要解决一个问题:如何统一团队代码风格。 这篇文章主要是使用pre-git , eslint , js-beautify 实现代码风格控制。 下面分别介绍这三
2022-06-04

如何解决Dreamweaver代码不自动提示的问题

这篇文章给大家分享的是有关如何解决Dreamweaver代码不自动提示的问题的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Dreamweaver代码不自动提示的问题,不论是HTML还是CSS,在网上搜索了半天,大
2023-06-08

如何使用Python代码自动生成文献的IEEE引用格式

小编给大家分享一下如何使用Python代码自动生成文献的IEEE引用格式,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!用Python写了一个小程序用于根据BibT
2023-06-14

如何设置CentOS系统以防止恶意代码的自动执行

为了防止恶意代码的自动执行,您可以采取以下步骤来设置CentOS系统:1. 及时更新系统:定期更新系统软件和补丁,以确保系统安全性。2. 安装防病毒软件:安装可信赖的防病毒软件,并定期更新病毒数据库。3. 禁用不必要的服务和端口:检查系统上
2023-10-10

如何实现检测网站down掉后自动发信的shell脚本代码

小编给大家分享一下如何实现检测网站down掉后自动发信的shell脚本代码,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!代码如下:#!/bin/bash#website test scriptswhile true;do
2023-06-09

如何利用PHP7的命名空间和自动加载机制组织代码的结构?

如何利用PHP7的命名空间和自动加载机制组织代码的结构?摘要:随着PHP7的推出,命名空间和自动加载机制成为了PHP开发中不可忽视的重要特性。本文将介绍如何利用PHP7的命名空间和自动加载机制来组织代码的结构,并通过具体的代码示例进行说明。
2023-10-22

如何利用PHP7的命名空间和自动加载机制组织和管理代码?

如何利用PHP7的命名空间和自动加载机制组织和管理代码?引言:在大型的PHP项目中,代码的组织和管理是非常重要的,可以提高代码的可读性、可维护性和可扩展性。PHP7引入了命名空间和自动加载机制,为我们提供了更好的代码组织和管理方式。本文将介
2023-10-22

如何使用PHP7的命名空间和自动加载机制提高代码的可维护性?

如何使用PHP7的命名空间和自动加载机制提高代码的可维护性在开发大型的PHP应用程序时,使用命名空间和自动加载机制是非常重要的。这些特性可以提高代码的可维护性,并且使得代码更易于理解和复用。本文将介绍如何使用PHP7的命名空间和自动加载机制
2023-10-22

如何利用PHP7的命名空间和自动加载机制提高代码的可读性和可维护性?

如何利用PHP7的命名空间和自动加载机制提高代码的可读性和可维护性?引言:在开发大型PHP应用程序时,代码的可读性和可维护性是非常重要的。使用好命名空间和自动加载机制,可以帮助我们更好地组织代码,使得代码结构清晰,代码之间的依赖关系明确,提
2023-10-24

如何使用PHP7的命名空间和自动加载机制提高代码的可读性和可维护性?

如何使用PHP7的命名空间和自动加载机制提高代码的可读性和可维护性?在现代的PHP开发中,代码的可读性和可维护性是至关重要的因素。为了更好地组织和管理代码,PHP7引入了命名空间和自动加载机制。通过合理使用命名空间和自动加载机制,我们可以提
2023-10-24

编程热搜

目录