02.标准化编程规范

news2024/9/29 3:32:15

1. 前言

在日常开发中,随着团队人员的变更,功能迭代,如果没有一套规范约束大家,就会导致项目中的代码充斥着各种代码风格,会导致后期维护起来十分困难,所以有必要去制定一套规范。互联网发展到今天,前辈们自然也想到了这点,所以有很多已经很完善的方案,这里我只介绍 ESlint + Prettier + commitizen + commitlint + lint-staged。

其实我认为养好良好的编程习惯很重要,而且应该定期开展 code review ,否则哪怕再完善的配置,最终也会导致项目变成“屎山”,包括 TS 都是为了项目易于维护,如果自己写项目,我不会加这些配置,影响开发效率,但是为了学习,这个项目我会加上这些配置以及使用 TS

这里我不想过多介绍,因为我认为这些来约束人的东西不是必要的,如果想要配置,可以跟着操作即可,也很简单。个人项目或者不太在意的直接跳过就行。

2. 编程规范

2.1. 代码检测工具 ESLint

这个初始化项目的时候,我就选择安装了,如果你和我选的一样应该是装上的,不过多介绍。想要进一步了解可参考官网 https://eslint.org/ 中文地址:https://zh-hans.eslint.org/。

我认为默认的规则就比较合理,如果想要修改默认规则可以在 .eslintrc.cjs 文件中进行修改,比如默认规则要求 vue 组件名称必须要由多个单词组成,否则会有提示,如果想要修改可以这样修改:

module.exports = {
  ...
  ...
  /**
   * 错误级别分为三种:
   * "off" 或 0 - 关闭规则
   * "warn" 或 1 - 开启规则,使用警告级别的错误:warn (不会导致程序退出)
   * "error" 或 2 - 开启规则,使用错误级别的错误:error (当被触发的时候,程序会退出)
   */
  rules: { // [!code ++]
    'vue/multi-word-component-names': 0 // [!code ++]
  } // [!code ++]
}

使用 npm run lint 可以检测编程规范,根据提示可以快速定位到问题代码。

2.2. 代码格式化工具 Prettier

这个在创建的时候,已经选择安装了, 这是一款开箱即用的代码格式化插件,可以直接通过 VSCode 安装整合。想要进一步了解,请参考官网:https://prettier.io/ 中文地址: https://www.prettier.cn/
在这里插入图片描述

如果想要修改代码风格,比如缩进,换行等等,可以看到一个 .prettierrc.json 的配置文件,这里可以配置我们统一的代码风格:

{
  "$schema": "https://json.schemastore.org/prettierrc",
  // 不使用尾行分号
  "semi": false,
  // tab键等于2个空格
  "tabWidth": 2,
  // 使用单引号
  "singleQuote": true,
  // 每行最大字符宽度,换行临界值
  "printWidth": 100,
  // 多行逗号分隔语法中,最后一行不加逗号
  "trailingComma": "none"
}

使用 npm run format 命令自动检测代码格式规范,会应用配置自动进行代码格式化

这里有的时候会出现与预期不符的情况,有可能是 VSCode 设置与配置项有冲突,可以修改配置或 VSCode 环境配置,使他们保持一致。以前我们习惯将 ESLintPrettier 整合到了一起,让语法校验的同时进行代码的格式化,但是从 ESLintVUE3 提供的脚手架工程默认配置 .eslintrc.cjs 可以看出(@vue/eslint-config-prettier/skip-formatting),ESLint 的主要要任务应该是语法的校验,而格式化的工作交给了 Prettier, 各司其职。如果最后还是出现爆红或者检测异常,尝试重启一下项目。

3. 代码提交规范

避免团队合作时大家提交信息乱写,不利于问题追溯, 现在市面上比较广泛应用的应该是 Angular 团队规范 延伸出的 Conventional Commits specification(约定式提交)。想要进一步了解,可查阅官方网站。用的比较多的应该就是 featfix

3.1. 使用 Commintzen 规范化提交代码

3.1.1. 全局安装Commitizen

想进一步了解可参考官方:https://github.com/commitizen/cz-cli

npm install -g commitizen
3.1.2. 安装并配置 cz-customizable

官方地址:https://github.com/leoforfree/cz-customizable

  • 安装依赖
npm i cz-customizable --save-dev
  • package.json 中添加以下配置
{
    ...
    "config": {
        "commitizen": {
            "path": "node_modules/cz-customizable"
        }
    },
}

3.1.3. 在项目根目录下创建 .cz-config.cjs 自定义提示文件
module.exports = {
  // 可选类型
  types: [
    { value: 'feat', name: 'feat:     新功能' },
    { value: 'fix', name: 'fix:      修复' },
    { value: 'docs', name: 'docs:     文档变更' },
    { value: 'style', name: 'style:    代码格式(不影响代码运行的变动)' },
    { value: 'refactor', name: 'refactor: 重构(既不是增加feature,也不是修复bug)' },
    { value: 'perf', name: 'perf:     性能优化' },
    { value: 'test', name: 'test:     增加测试' },
    { value: 'chore', name: 'chore:    构建过程或辅助工具的变动' },
    { value: 'revert', name: 'revert:   回退' },
    { value: 'build', name: 'build:    打包' }
  ],
  // portal 门户,system 后台管理系统
  scopes: ['', 'portal', 'system'],
  // 消息步骤
  messages: {
    type: '请选择提交类型:',
    customScope: '请输入修改范围(可选):',
    subject: '请简要描述提交(必填):',
    body: '请输入详细描述(可选):',
    footer: '请输入要关闭的issue(可选):',
    confirmCommit: '确认使用以上信息提交?(y/n/e/h)'
  },
  // 跳过问题
  skipQuestions: ['body', 'footer'],
  // subject文字长度默认是72
  subjectLimit: 200
}

package.json 添加以下配置, 否则会提示错误

"config": {
    "cz-customizable": {
        "config": ".cz-config.cjs"
    }
}
3.1.4. 使用 git cz 代替 git commit

测试一下提交
在这里插入图片描述

可以看到配置生效了,选择填写提交信息后 git push

在这里插入图片描述

这里还可以指定 customScope 修改范围,默认为 customer,我不喜欢,如果未指定则不要给我显示 修改配置 .cz-config.js,添加自定义的范围,可根据自己项目情况添加,比如我是按照门户网站和管理系统来区分的,选择空字符串则不会有修改范围。

{
  ......
  scopes: ['', 'system', 'portal'],
}

3.2. 使用 husky + commitlint 检查提交是否规范

我们使用 git cz 代替 git commit 实现了规范化的提交,但是无法避免有的时候忘记,习惯性使用 git commit 提交,这个时候我们就需要添加一层校验,来规避这种情况

3.2.1. 认识 Git Hooks

无论我们怎么变着花的提交代码,最终的执行命令都是 git 工具完成的,而 git 支持在执行某个事件之前或者之后进行一些其他的额外操作,为我们提供了很多事先就定义好的 钩子函数hooks

想要进一步了解有哪些钩子可参考官方文档:https://git-scm.com/book/zh/v2/%E8%87%AA%E5%AE%9A%E4%B9%89-Git-Git-%E9%92%A9%E5%AD%90. 这里我只介绍将要用到的两个,commit-msg , pre-commit.

  • commit-msg: 用来规范化标准格式
  • pre-commit: 会在提交之前调用
3.2.2. 使用 commitlint 检查提交的信息

想进一步了解,移步至官方文档:https://github.com/conventional-changelog/commitlint

  • 安装
npm install --save-dev @commitlint/config-conventional @commitlint/cli
  • 生成配置文件
echo "module.exports = {extends: ['@commitlint/config-conventional']}" > commitlint.config.ts
module.exports = {
  extends: ['@commitlint/config-conventional'],
  // 定义规则类型
  rules: {
    // type 类型定义,表示 git 提交的 type 必须在以下类型范围内
    // 0:禁用规则,不会对提交类型进行验证。
    // 1:警告级别,对提交类型进行验证,但不会阻止提交。
    // 2:错误级别,对提交类型进行验证,如果不符合规则将阻止提交。
    // 'always':规则始终适用于提交消息中的提交类型。无论提交消息的内容如何,都会应用该规则进行验证。
    // 'never':规则永远不适用于提交消息中的提交类型。无论提交消息的内容如何,都不会应用该规则进行验证。
    'type-enum': [
      2,
      'always',
      [
        'feat', // 新功能 feature
        'fix', // 修复 bug
        'docs', // 文档注释
        'style', // 代码格式(不影响代码运行的变动)
        'refactor', // 重构(既不增加新功能,也不是修复bug)
        'perf', // 性能优化
        'test', // 增加测试
        'chore', // 构建过程或辅助工具的变动
        'revert', // 回退
        'build' // 打包
      ]
    ], // subject 大小写不做校验
    'subject-case': [0]
  }
}

:::warning

确保保存为 UTF-8 的编码格式,否则可能会报错

:::

3.2.3. 使用 husky 触发钩子,自动完成提交校验

https://typicode.github.io/husky/

  • 安装
npm install husky --save-dev
  • 初始化,生成 .husky 文件夹
npx husky init
  • 修改 .husky/pre-commit
npm run lint
  • 添加 commit-msg 钩子,完成自动校验
#!/usr/bin/env sh
npx --no -- commitlint --edit ${1}

在这里插入图片描述

可以看到检测出我们提交信息不规范

3.3. 使用 lint-staged 自动修复格式错误

我在整合这个的时候有这样的疑问,我们既然有钩子了,为什么不直接在钩子里再执行一遍代码格式化脚本,npm run format 而是要去使用 lint-staged 呢?
通过了解后明白,原来 lint-staged 值得被使用是因为,如果我们哪怕只改了 1 个文件,如果通过钩子,提交的时候是要重新去检测校验所有代码,显然是不合适的,而 lint-staged 可以只对即将提交的文件进行检查,确保每次提交都符合规范,这样提升了项目提交效率。

t-staged 仅仅是一个文件过滤工具,过滤 git 暂存区里的文件

想进一步了解参考官方说明:https://github.com/okonet/lint-staged

3.3.1. 安装
npm install --save-dev lint-staged
3.3.2. 修改 package.json
{
  ...
  "lint-staged": {
    "src/**/*.{js,ts,vue}": [
      "eslint --fix",
      "prettier --write"
    ]
  },
}
...

3.3.3. 修改 pre-commit 钩子中的脚本
# 将 npm run lint 修改为 npx lint-staged
npx lint-staged
3.3.4. 故意修改一处语法错误和代码格式错误测试

在这里插入图片描述
可以看到自动执行了钩子,进行了检测修复

4. 总结

到这里整体配置就算完成了,简单总结一下,编程规范主要分为两方面:

  • 代码格式的规范
  • git 提交规范

明确这里使用的一些插件的作用:

  • ESlint 代码检测工具

  • Prettier: 代码格式化工具

  • commitizen: git 提交规范化工具

  • commitlint: 用于检测提交信息规范化的插件

  • lint-staged: 过滤需要检测的 git 暂存区的文件插件

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2088172.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

九月更新|用这个方法,小白在国内也能轻松使用ChatGPT,GPT新手使用手册(编程代码)

一、 ChatGPT可以做什么? ChatGPT能做的事情非常多!它不仅仅是一个对话AI。以下是一些主要功能: 1. 回答问题:无论是学术问题、技术问题,还是生活琐事,ChatGPT都能提供帮助。 2. 写作助手:可以…

html+css 实现 带射灯的浮雕按钮

前言:哈喽,大家好,今天给大家分享html+css 实现 带射灯的浮雕按钮!并提供具体代码帮助大家深入理解,彻底掌握!创作不易,如果能帮助到大家或者给大家一些灵感和启发,欢迎点赞、收藏+关注哦 💕 文章目录 效果原理解析1.此按钮效果主要是运用了==css3属性的box-shadow和…

用实时计算释放当下企业大数据潜能

摘要:本文整理自阿里云高级产品解决方案架构师王启华(敖北)老师在 Flink Forward Asia 2023 中闭门会的分享。内容分为以下五个部分: 1. 实时计算在大数据计算发展中的趋势 2. 实时计算对于企业生产的意义 3. 阿里云飞天大数据产品…

Nginx实验-2

Nginx中的变量 变量可以分为内置变量和自定义变量 内置变量是由nginx模块自带,通过变量可以获取到众多的与客户端访问相关的值 [rootnginx ~]# cd /usr/local/nginx/ [rootnginx nginx]# cd conf.d/ [rootnginx conf.d]# ls status.conf vhost.conf [rootngin…

五种多目标优化算法(NSGA3、MOPSO、MOGWO、NGSA2、SPEA2)性能对比,包含47个多目标测试函数,6种评价指标,MATLAB代码

一、五种多目标算法及六种评价指标简介 多目标灰狼优化算法(MOGWO): MOGWO是由Mirjalili等人在2016年提出的,基于灰狼优化算法(GWO)的多目标版本。它引入了存档机制和改进的头狼选择方式,以处理…

【Python报错已解决】`TypeError: an integer is required (got type bytes)`

🎬 鸽芷咕:个人主页 🔥 个人专栏: 《C干货基地》《粉丝福利》 ⛺️生活的理想,就是为了理想的生活! 文章目录 引言一、问题描述1.1 报错示例1.2 报错分析1.3 解决思路 二、解决方法:2.1 方法一2.2 步骤二 三、其他解决…

39次8.29(了解docker-compose,docker-compose编排容器,配置harbor服务)

1.使用使用docker-compose编排容器 1.YAML ⽂件的格式和语法 1)YAML ⽂件格式 yaml 是⼀种标记语⾔很直观的数据序列化格式,可读性很⾼。 类似于 xml 描述性语⾔,语法⽐xml简单的很多。 yaml 数据结构通过缩进进⾏表示,连续的…

AI绘画与《黑神话:悟空》的碰撞,擦出不一样的火花!

在当今数字时代,利用人工智能技术创造艺术作品已成为一种引人注目的趋势。 特别是在社交媒体平台上,如小红书,通过展示AI绘画作品可以吸引大量关注,增加曝光率,并且为自己带来潜在的商业机会。 如果你是《黑神话&…

sql-labs31-35关通关攻略

第三十一关 一.判断闭合 1“” 二.查询数据库 http://127.0.0.1/Less-31/?id-1%22)%20union%20select%201,2,database()--http://127.0.0.1/Less-31/?id-1%22)%20union%20select%201,2,database()-- 三.查表 http://127.0.0.1/Less-31/?id-1%22)%20union%20select%201,…

java实现ocr功能(Tesseract OCR)

1、pom文件中引入依赖 <dependency><groupId>net.sourceforge.tess4j</groupId><artifactId>tess4j</artifactId><version>4.5.4</version> </dependency> 2、下载语言库文件&#xff08;不要放到resources下&#xff0c;可…

Python TensorFlow 实战指南

引言 TensorFlow 是一个功能强大的开源库&#xff0c;被广泛应用于数值计算和机器学习任务。本指南旨在帮助读者理解如何使用 Python 和 TensorFlow 构建机器学习模型。我们将从基础开始&#xff0c;逐步深入到更复杂的主题。 第一部分&#xff1a;入门 第1章&#xff1a;T…

基于vue框架的仓库物流信息管理系统设计和实现0a6d7(程序+源码+数据库+调试部署+开发环境)系统界面在最后面。

系统程序文件列表 项目功能&#xff1a;供应商,商品分类,商品信息,商品入库,车辆信息,订单出库,订单发货,订单抵达,用户 开题报告内容 基于Vue框架的仓库物流信息管理系统设计和实现 开题报告 一、研究背景与意义 随着全球电子商务的蓬勃发展和物流行业的迅速崛起&#xff…

电子设备网络新航向:SEO携手新媒体,打造强势品牌曝光

电子设备企业怎么有效地进行网络推广&#xff0c;把业务越做越好呢&#xff1f;根据湖南竑图网络13年从事互联网优化经验来看&#xff0c;可以给大家分享几点&#xff0c;希望对各位企业老板和高管有一定作用&#xff01; 一、关键词优化。搜索关键词依旧是传统企业获取精准流量…

Three.js Cesium.js 案例聚集地

对于大多数的开发者来言&#xff0c;看了很多文档可能遇见不到什么有用的&#xff0c;就算有用从文档上看&#xff0c;把代码复制到自己的本地大多数也是不能用的&#xff0c;非常浪费时间和学习成本&#xff0c; 尤其是three.js &#xff0c; cesium.js 这种难度较高&#xff…

kubesphere-devops环境-修改maven源到阿里云

文章目录 前言一、maven配置文件在kubesphere中的位置二、修改configmap&#xff0c;增加阿里源信息总结 前言 使用kubesphere搭建了devops环境&#xff0c;但是在构建maven的时候&#xff0c;发现使用的是官方的镜像&#xff0c;修改为阿里云的mirrors 一、maven配置文件在ku…

用Django框架+爬虫技术实现自动获取可画(Canva)团队会员资格的方法

可画(canva)是一个非常流行的在线平面设计平台,因为它无需专业训练和技能就可以利用其丰富的资源设计出美观、酷炫的作品,这些作品可以是视频、广告、演示文稿、网站页面、社交媒体界面、商业标识等等,因而它受到了极其广泛的设计专业和非专业人群的喜爱。在可画平台上,不…

PHP房产管理多终端系统灵活应对各种管理需求系统小程序源码

房产管理多终端系统&#xff0c;灵活应对万变管理需求&#x1f3e0;&#x1f4bc; &#x1f308; 开篇&#xff1a;房产管理的挑战与机遇 在房产行业日益繁荣的今天&#xff0c;管理需求也变得复杂多样。&#x1f914; 无论是大型房企还是小型中介&#xff0c;都面临着房源信息…

前端Vue使用AES的GCM模式加密

文章目录 前端加密测试Java加解密代码 写了个新的前端项目&#xff0c;公司要求&#xff0c;账号密码这些必须是加密传输的&#xff1b;后端使用了GCM模式加密&#xff0c;前端是复制的一个以前项目的代码&#xff0c;原来是有写加密的&#xff0c;使用的是CryptoJS组件CTR模式…

学生用的蓝牙耳机推荐有哪些?四款TOP榜单高人气机型分享

作为一个蓝牙耳机的重度使用党&#xff0c;耳机已经成为了学生们不可或缺的学习伴侣&#xff0c;声音对于我们学生党来说&#xff0c;选择一款性价比高、舒适度好且续航能力强的蓝牙耳机尤为重要&#xff0c;那么学生用的蓝牙耳机推荐有哪些&#xff1f;今天我就为大家推荐四款…

【机器学习】决策树------迅速了解其基本思想,Sklearn的决策树API及构建决策树的步骤!!!

目录 &#x1f354; 案例剖析 &#x1f354; 通过sklearn实现决策树分类并进一步认识决策树 &#x1f354; 基于规则构建决策树 &#x1f354; 构建决策树的三个步骤 &#x1f354; 小结 学习目标 &#x1f340; 了解决策树算法的基本思想 &#x1f340; 了解Sklearn的决策…