码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Lint-staged自动修复格式错误及小结


    文章目录

      • 一、背景
      • 二、Lint-staged
        • 2.1 简介
        • 2.2 修改package.json
        • 2.3 修改pre-commit
        • 2.4 测试
      • 三、小结
        • 3.1 代码格式规范
        • 3.2 Git提交规范

    一、背景

    通过前面几节的介绍,目前想要提交代码,就要保证代码格式规范和提交信息格式规范,特别是pre-submit会检测所有代码的格式规范,这就会存在两个问题:

    • 假如我们只修改了个别文件,就没有必要检测所有的文件代码格式
    • 目前只能给我们提示出对应的错误,还需要手动进行代码修改

    二、Lint-staged

    2.1 简介

    要处理上面两个问题,就需要使用lint-staged插件了。

    lint-staged可以让当前的代码检查只检查本次修改更新的代码,并在出现错误的时候,自动修复且推动

    lint-staged无需单独淡妆,在生成项目时,vue-cli已经帮我们安装过了,所以直接使用即可。

    2.2 修改package.json

    修改package.json,如下:

    "lint-staged": {
      "src/**/*.{js,vue}": [
        "eslint --fix",
        "git add"
      ]
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    如上配置,在每次本地commit之前,校验提交的内容是否符合本地配置的eslint规则,校验会出现两种情况:

    • 符合规则:提交成功
    • 不符合规则:自动执行eslint --fix尝试自动修复,如果修复成功,则自动把修复后的代码提交,如果失败,会提示错误,手动修复后才允许提交代码

    2.3 修改pre-commit

    在.husky中的pre-commit,修改指令,如下:

    #!/bin/sh
    . "$(dirname "$0")/_/husky.sh"
    
    # npx eslint --ext .js,.vue src
    npx lint-staged
    
    • 1
    • 2
    • 3
    • 4
    • 5

    2.4 测试

    将HomeView中的单引号修改为双引号,执行提交操作,如下:
    在这里插入图片描述
    这样就完成了代码格式的自动修复及提交。

    三、小结

    在这几篇文章中,主要处理了编程格式规范的问题,整个规范分为两大类:

    • 代码格式推翻
    • Git提交规范

    3.1 代码格式规范

    对于代码格式规范,通过ESLint + Prettier + VSCode配置配合进行了处理,最终达到了在保存代码时自动规范化代码格式的目的。

    3.2 Git提交规范

    对于git提交规范,我们使用了husky来检测git hooks钩子,并且通过以下插件完成了对应的配置:

    • 约定式提交规范
    • commitizen:git提交规范化工具
    • commitlint:检查提交信息规范
    • pre-commit/commit-msg:git hooks钩子
    • lint-staged:只检查本次修改更新的代码,并在出现错误的时候自动修复并推送
  • 相关阅读:
    第二章范式
    docker自定义网络下 :不同容器的nginx通过容器名称相互访问PHP项目
    5、CSS——三种样式和样式优先级、CSS中颜色设置方式、标签选择器和基本选择器的优先级
    JS中Promise对象及其使用方式
    tp6教程
    【保姆级】lookup-method标签实践与分析
    复杂度为O(NlogN)的归并排序
    Java SE 12 新增特性
    这才是数字孪生污水处理厂该有的样子 | 智慧水务
    C语言函数(2)
  • 原文地址:https://blog.csdn.net/u010358168/article/details/128037788
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号