面对躺平同事,我开发了一个插件治好了我的精神内耗⚡⚡⚡

简介: 面对躺平同事,我开发了一个插件治好了我的精神内耗⚡⚡⚡

插件已经开源了,可以看文章末尾

console狂魔能有多狂

事情是这样的,前段时间我加入了公司某个小项目组

入组第一天,我要来了项目权限,下载完代码和依赖

然后npm start,打开浏览器控制台,

我尼玛,一个登陆页面就这么多log

此刻我怀着忐忑的心情打开了自己的即将负责的模块入口页面:

这让我怎么调试啊?

上图我已经把敏感信息屏蔽掉了(^/ω\^),每点击下页面就会蹦出好几行console

全局一搜索,居然有近800多条console语句。

起初,我为了方便我调试,我把影响我调试的console一一注释了,真是个体力活。

就在我开心了几天后,同事在开发群里发问了,“我调试打印的console怎么不见了?”,

我说我注释了,那么多console我没法调试啊,然后就被好几个同事”围攻“了,

后来想想没经过人家的同意修改人家的代码确实不对!

其实从他们的代码来看,完全是躺平的状态,完全放弃了公司的代码规范,真的很让人emo。

emo时间的思考

既然人家喜欢那样做,我也没办法,emo了一会,我就寻找别的方法解决让我强迫症发作的方法。

第一种方法是如果有console就不让提交代码,显然不现实,

第二种方法是使用去除conosle的插件,但是有个缺点,我的console也会被去掉,

焦虑了好久,我就想到,有没有一种插件,在开发环境只展示开发者自己的console,但是不影响别人开发时调试。

找了好久都没找到,那就自己动手开发一个吧。

我的思路是

  • 在每个文件中匹配console语句
  • 用匹配到的行,请求git,查看当前行的作者
  • 如果不是我就统统删除console之后再build

这样既不会干扰我开发,也不会影响别人开发调试了。

上次的文章已经介绍了vite的插件开发了,这里就不赘述了。

我们开发的插件主要是在文件编译时,将文件中的console智能的清除,对应的插件hook为transform。基本的结构如下。

const RemoveConsole = (): {
  name: string;
  enforce: 'pre';
  transform: (code: string, id: string) => any;
} => {
  return {
    name: 'remove-console',
    enforce: "pre",
    transform: (code, id) => {
      // todo something
      return code
    }
  }
}

接下来一步步实现,

匹配console语句

如果文件中存在console则进行分析,否则返回原代码。

分析过程:

  1. 按行划分
  2. 分析出包含console的行

查询git作者

主要使用child_process子进程运行git命令,根据命令的返回结果分别处理,

例如我们或者当前作者:

const userName = childProcess.execSync(
  `git config user.name`,
  { encoding: 'utf-8' }
)
console.log(userName)
// mmdctjj

分析每行作者,使用的git命令是

// 查看指定问价你的l1到l2行的作者详细信息
git blame -L l1,l2 --porcelain filepath

我们还需要在此基础上改造下,完整的命令如下:(win不知grep命令,可以使用findstr代替)

git blame -L ${line+1},${line+1} --porcelain ${id} | grep "^author "

接着从字符串中截取出作者

const author = authorInfo.slice(authorInfo.indexOf(`author `) + 7)

根据当前作者和conosle的作者是否相等。我们得出需要删除的行

// 需要删除的行
 const removeLine = includesLines.filter(line => {
    const authorInfo = childProcess.execSync(
      `git blame -L ${line+1},${line+1} --porcelain ${id} | grep "^author "`,
      { encoding: 'utf-8' 
    )
    const author = authorInfo
      .slice(authorInfo.indexOf(`author `) + 7)
      .split('\n')[0]
    return author !== userName
})

删除console

接着我们遍历每一行,进行替换

const newRows = rows.map((row, idx) => {
  if (removeLine.includes(idx)) {
    // 正则表达式替换完整的console.log语句 
    return row.replace(/console\.log\((?:[^)(]|\((?:[^)(]+|\([^)(]*\))*\))*\)[;\n]?/g, '')
  }
  return row
})
const newContent = newRows.join(`\n`)
return newContent

测试

我们验证下效果。这个文件中有多个console语句

十分完美!!!

今天的分享就到这了,感谢你的观看,如有错误的地方,欢迎指正!

最后附上我的

🚀 vite插件: rollup-plugin-remove-others-console

插件地址:https://www.npmjs.com/package/rollup-plugin-remove-others-console

github地址:https://github.com/mmdctjj/rollup-plugin-remove-others-console

🚀 webpack loader: remove-others-console-loader

loader地址:https://www.npmjs.com/package/remove-others-console-loader

github地址:https://github.com/mmdctjj/remove-others-console-loader

功能还会继续完善,欢迎star⭐

相关文章
|
8月前
|
机器学习/深度学习 分布式计算 算法
【活动】程序员的核心职业素养:技术与人文并重的探索之旅
在数字化浪潮席卷全球的今天,程序员作为构建未来世界的“魔法师”,其职业素养不仅关乎代码的优美与效率,更深层次地体现在对技术的持续追求、团队合作的能力、解决问题的创新思维以及对社会责任的担当上。本文将探讨我认为对于程序员最为重要的几种职业素养,并结合实际案例,分享我在职业生涯中的体会与思考。
98 4
|
9月前
|
负载均衡 Kubernetes 数据库
【鹅厂摸鱼日记(一)】(工作篇)认识八大技术架构
【鹅厂摸鱼日记(一)】(工作篇)认识八大技术架构
|
SQL 移动开发 数据可视化
颠覆你的认知,业务同事都能开发软件,我简直无地自容……
颠覆你的认知,业务同事都能开发软件,我简直无地自容……
|
消息中间件 分布式计算 Kubernetes
爆款阿里P5到P7晋升之路,九大源码文档助我超神果然努力幸运并存
前言 相信有许多的程序员,工作了这么多年;但是依然不知道自己掌握的技术栈+项目,究竟达到了阿里的什么职级,还有薪资水平是什么样的;
|
搜索推荐 Java 程序员
只有一个程序员开发和运营,BuiltWith网站年入1400万美元是怎么做到的?
国外有一位程序员叫 Gary Brewer,他一人撑起了一个公司,这个公司还年入 1400 万美元,约人民币 1 亿元。对此,你是啥想法?
207 0
|
监控 前端开发 jenkins
新来个技术总监,给团队引入了这款开发神器,同事直呼哇塞
带团队时间久了,就能发现整个 Team 都渐渐疲了。前两年老板还专门买了个系统搞 OKR,现在也不大提了;Scrum 我们也搞了,用起来也就那样;项目管理工具试了好几个,禅道、Worktile、现在用 Coding,反正有一个能用的就行;微服务化改造从去年开始在吭哧吭哧搞,我们自己搞得觉得很厉害,但业务部门那边就觉得没啥差别,搞不懂你们研发部门每天在弄些什么,赶紧做我们提的需求要紧。
新来个技术总监,给团队引入了这款开发神器,同事直呼哇塞
|
存储 程序员 项目管理
六年团队Leader实战秘诀|程序员最重要的八种软技能
笔者在带团队的六年中发现,程序员们在职场都有一个共同的困扰:“好像写代码都没什么问题了,日常工作基本上都是应付业务需求的开发,好像找不到其他的更大的附加价值了,我应该找一些什么样的发力点才能让我的价值更突出呢?” 。本文将和大家聊聊程序员的软技能。
六年团队Leader实战秘诀|程序员最重要的八种软技能
|
程序员 数据库
“科班出身”的程序员和“培训出身”的程序员的大型辩论(甩锅)现场
前几天阿粉说阿粉最近换了公司,而且入职之后干掉了公司里面的测试数据库的事情,而接下来的事就比较有意思了,来自“科班出身”的哥们和来自“培训出身”的我的大型辩论(SIBI)现场,也不能说是通俗的甩锅,但是确实有那么点意味。
“科班出身”的程序员和“培训出身”的程序员的大型辩论(甩锅)现场
|
前端开发 JavaScript 开发者
副业刚需?同事就用这 10 个开源项目接私活!
副业刚需?同事就用这 10 个开源项目接私活!
196 0
副业刚需?同事就用这 10 个开源项目接私活!