写点什么

为什么我不是 Vim 的狂热粉丝?

  • 2022-08-03
  • 本文字数:2200 字

    阅读完需:约 7 分钟

为什么我不是 Vim 的狂热粉丝?

有大量的开发人员在开发过程中使用 Vim,我是那些认为 Vim 很糟糕的人之一,听我说说吧。

 

前不久,我在之前的一篇文章里曾说过,我非常讨厌使用 Vim 来进行开发,很多人对我和我的看法提出了疑问。本文不仅阐明了这个问题,也解释了为什么我没有将 Vim 推荐给别人用于开发。

 

我敢肯定有些人不赞同我这些观点,这是好事。以下列出的一切都是我个人的观点,每个人的观点也都不同,如果是这样的话,或许我会让你改变主意,让我们开始吧。



而且,标题是“为什么我不是 Vim 的狂热粉丝”,而不是“为什么你应该停止使用 Vim”。总之,这就是我的观点,别把它当回事。


Vim 是什么?

 

Vim 是一款基于终端的文本编辑器,它可以被配置成几乎任何东西,从一个基本的功能编辑器到一个完整的、功能丰富的 IDE。

 

它采用了“模式系统”,你可以通过“i”、“ESC”以及其他一些键来进行各种模式的切换,比如插入模式、可视模式、正常模式等,并与文档进行交互。



默认情况下,Vim 看上去是空的,但在定制方面,文本编辑器可以被做成接近任何东西的样子。至少对 Vim 来说,定制是最大的关键。更不用说,这款文本编辑器几乎可以塞进任何功能,并被重新加工成其他类似的文本编辑器。一些类似的编辑器包括 Vi、Neovim 等。

 

文本编辑器确实是一头“野兽”,可以被做成几乎任何东西。


我碰到的问题

 

然而,凡事总有坏处,Vim 中存在许多缺陷,让我无法将其用于开发中。以下是几条:

思想观念



对于所有想知道的人来说,你按了 Esc 键进入正常模式,然后敲“:q!”

 

作为一名开发者,所用的程序,可能应该照顾到从 git 到自动完成,到语法高亮,诸如此类。我是说,如果你是一名开发者,你显然更倾向于语法自动完成、git 集成、图形化,和其他一些缺省的功能,而不是我们花时间自己做,因为 Vim 是为开发者设计的。

 

Vim,让我们配置我们想要的东西。但是,这需要我们进行配置,而这些都是大家都需要的,并且可以在 Vim 中默认添加。

 

那么,你也许会问,那些不需要额外功能的人呢?这个问题问得很好。一些非开发者,他们也使用 Vim,不需要任何自动完成或者相似的功能。这就是 Vi 或者 vi-minimal,因此这应该是可行的。

 

工作流——不同的模式


要是你明白了这一点,恭喜你。你理解了 Vim 的工作流。

 

以另一款文本编辑器为例,比方说 Atom 或 Sublime,我们会有一个有“模式”的界面,你只需要输入你所需要的内容。这样既能节约时间,又能提高工作效率。

 

我是说,即使从逻辑上讲,在打字之前按“i”键,在拷贝之前按“Shift+V”组合键,这在工作时可能看起来是一件小事,但从长远来看,至少对我而言,是完全多余的。

 

也许有人会说,由于“模式系统”在很大程度上是基于键盘的,所以它可以帮助工作流。但是,即使是这样,我也可以 Atom 这种通用的文本编辑器,在任何地方都可以只用键盘和一种模式进行工作。

 

即使是最微小的事情,比如撤销,我们也必须要按 Esc 键,确保我们处于正常模式,然后再按“u”键,我想直接按“Ctrl+Z”组合键会更快捷。更不用说,要适应这个非同一般的工作流,将会耗费很多的时间。

 

基于终端


文本编辑器中的 vim

 

现在,也许很多人会认为这是一种优势。当然,作为一款可以直接从终端上打开的文本编辑器,它确实有很多优势。我的意思是,它大概就是我在 tty(CUI)界面中所用到的文本编辑器。

 

不过,我个人觉得,它从终端上工作,存在很多缺陷。第一个最大的缺陷是,除了文本之外,它无法看到任何内容,这看起来可能是件小事,但是对于那些经常涉及图形的游戏开发者却没有太大的用处。同时,我可以在 Atom、Sublime 之类的文本编辑器快速查看任何意图。

 

很耗费时间……



Vim 是一款需要花费大量的时间来进行配置和使用的文本编辑器,但其实不值得。我说的是真心话。

 

我用了三四年的时间来建立自己的高配置 vimrc 文件,并且已经适应了 Vim 的基础工作流。不过,到了最后,我发现我可以用“普通”的文本编辑器来完成相同的工作,而不用花几年的时间来调整。更不用说,像 VSCode 这样的文本编辑器,只要登陆你的微软账户,就能得到所有你已经完成的“配置”。(译者注:原文有误,VSCode 并不能直接使用微软账户进行同步配置,要用到 Setting Sync 的 VSCode 插件才能做到同步配置)。而 Vim 则需要一个多小时才能做好充分的准备工作(那是我已经用了好几个月来建立我的 vimrc 并且已经适应的前提下)。比起 VSCode,登陆时间连 2 分钟都不到,你能明白我要表达什么意思吗?

 

太陈旧了(奖赏)



我称这是一种奖赏,因为陈旧总是不意味着坏,但有时候,它意味着过时。在我看来,Vim 对于这样一款文本编辑器来说实在是太过陈旧了,它仍然使用“hjkl”键来移动光标。对于那些不知道的人来说,在键盘真正实现单独的方向键之前,“hjkl”键是被当作方向键使用。

 

另外,还有一个简单的附带说明,那就是它在最近没有得到改进。我的意思是,Vim 在最近的几个发布版本中加入了一些不常用的命令,集成了一些新的插件,还有一些后端的小改动。与其他编辑器相比,它需要更快的开发进展。

 

总结

 

我将在 YouTube 上制作更多的视频,但我的观点是这样的:为了使文本编辑器更高效,Vim 的努力似乎有点过头了,而这种努力本身就没有抓住重点。

 

作者介绍:

 

FadinGeek,拥有多重身份:佛教徒、Youtube 播主、开发者、设计师和编辑。

 

原文链接:

 

https://medium.com/interviewnoodle/why-im-not-a-big-fan-of-vim-vim-like-text-editors-7120889dce1d

2022-08-03 18:336621

评论 9 条评论

发布
用户头像
防民之口, 甚于防川, 一个健康的人, 会害怕几声咳嗽就丢了性命吗?
2025-06-10 10:42 · 四川
回复
用户头像
真的服了,发个技术评论, 居然也能触发关键词?!, 而且也不知道是哪个关键词, 不知道会不会有一天, "关键词"也会成为关键词?
2025-06-10 10:39 · 四川
回复
用户头像
VS Code早就可以直接同步了

(译者注:原文有误,VSCode 并不能直接使用微软账户进行同步配置,要用到 Setting Sync 的 VSCode 插件才能做到同步配置)

2022-08-05 11:23
回复
用户头像
没有VIM的编辑器一概进入我的黑名单
2022-08-04 15:08
回复
为啥啊, 可以说说原因吗
2025-06-10 10:45 · 四川
回复
用户头像
如果一个编辑器没有VIM模式,那这个编辑器不值得使用。
2022-08-04 08:50
回复
为啥啊, 为何明明是 如果-那么 句式, 却感受不到半分逻辑?
2025-06-10 10:46 · 四川
回复
用户头像
感觉作者过于片面了,vim有vim的优势,其它文本编辑器也有各自的优势,并没有谁一定比谁好,比如,在vscode中使用vim插件,在可以全键盘快速操作的同时,也可以使用vscode的快捷键进行补充,例如使用command+z进行撤销,不冲突的,反而会更便捷。
2022-08-04 08:36
回复
mac相比Windows多了cmd键,对于vim使用者很友好,规避了许多快捷键冲突,Windows上系统的ctrl和vim的ctrl冲突,win键又很鸡肋,这也是我的工作电脑从win转到mac的一个原因
2022-08-05 17:05
回复
没有更多了
发现更多内容

文心与飞桨共享生态下的大模型训推部署创新实践计划

百度开发者中心

人工智能 大模型

gRPC 和 RPC:分布式系统通信的核心机制解析

Apifox

程序员 gRPC 网络协议 RPC grpc双向流

云上rds是暴利吗?是我们用tidb来替代他。

TiDB 社区干货传送门

数据库架构设计

tidb-v7.4初体验

TiDB 社区干货传送门

7.x 实践

Postgres 中文周报:Postgres Weekly 537 期

酷克数据HashData

软件测试/测试开发/全日制/测试管理丨selenium的三种等待方式

测试人

软件测试

等保三级测评:TiDB 客户端服务端间通信开启加密传输实践

TiDB 社区干货传送门

实践案例 数据库连接

喜讯!云起无垠入选2023年度中国数字安全能力图谱

云起无垠

软件测试/测试开发全日制|Pytest测试框架Fixture作用域详解

霍格沃兹测试开发学社

软件测试开发/全日制/测试管理丨Web自动化测试不同场景定位方式

测试人

软件测试

铭文 LaunchPad 平台 Solmash 推出早鸟激励计划

西柚子

AI时代下的智能商品计划如何助力服装企业实现库存精准优化

第七在线

浅尝在 Rocky 9 下自助生成 PDF 格式的 TiDB 文档

TiDB 社区干货传送门

管理与运维

速查!优惠券核销情况(支付宝优惠券)

盐焗代码虾

支付宝 经验分享 券核销

【Java技术专题】「攻破技术盲区」攻破Java技术盲点之unsafe类的使用指南(打破Java的安全管控— sun.misc.unsafe)

码界西柚

Java 后端 unsafe 原理分析 2024年第八篇文章

软件测试/测试开发全日制|Pytest中yield的用法详解

霍格沃兹测试开发学社

TiCDC同步kafka问题总结

TiDB 社区干货传送门

实践案例 6.x 实践

图像处理 - 自动纠偏 -JAVA

alexgaoyh

Java 图像处理 自动纠偏 傅里叶频谱 霍夫变换

大模型推理优化实践:KV cache复用与投机采样

阿里技术

大模型 推理优化 KV cache 投机采样 RTP-LLM

【标准解读】物联网安全的系统回顾

不在线第一只蜗牛

软件 物联网 项目开发

软件测试/测试开发/全日制/测试管理丨Web测试框架Selenium

测试人

软件测试

荣耀开发者大会2023 · 一张图读懂开发者服务分论坛

荣耀开发者服务平台

开发者大会 生态共建 honor 分发

TiDB × 杭州银行丨首个云原生、分布式、全栈国产化银行核心业务系统投产上线

TiDB 社区干货传送门

实践案例

drainer 异常宕机原因分析

TiDB 社区干货传送门

集群管理 6.x 实践

如何通过kube-apiserver访问K8s集群中的App

华为云开发者联盟

开发 华为云 k8s集群 华为云开发者联盟

vue3 + tsrpc +mongodb 实现后台管理系统

--linshuai

mongodb nodejs Vue3 后台管理系统

如何使用TiDB中的Placement Rules功能

TiDB 社区干货传送门

7.x 实践

图像边缘检测-去黑边-JAVA

alexgaoyh

Java 图像处理 去黑边 边缘检测 canny

为什么我不是 Vim 的狂热粉丝?_大前端_FadinGeek_InfoQ精选文章