Code with Kristian • I make videos and write about software development and programming tools
Here's what you need to learn and master Vim, the modal text editor 🤸♀️
Let's dig into the what, the why, and the how of learning Vim, the world's most popular modal text editor.
Vim (Vi IMproved) was first released in 1991 by Bram Moolenaar. It started as a clone of
vi, a Unix text editor initially released in 1976.
Vim (and Vi) are modal text editors: they have contextual "modes" that allow you to interact with the text in your file in different ways. Vim has modes for different situations –
insert for when you're writing text,
visual for selecting text and manipulating it,
normal for navigating through your document, and many more for ancillary situations.
Here's Greg Hurrell on modal text editors:
A modal text editor is a, nowadays rare, text editor that offers multiple interaction modes which are optimized for specific types of action and interaction. The rationale is that each mode is a finely-tuned tool which allows the user to realize their objectives in an efficient and powerful manner. This does require more learning than you might be accustomed to as a user of a non-modal editor, but the reward is hopefully increased efficiency and power.
Last week, we looked at the most popular editor in the world, VSCode.
Our focus was on productivity – most readers of Bytesized probably know of VSCode, and are probably using it.
The same generally can't be said of Vim: only 25% of people surveyed in Stack Overflow's 2019 Developer Survey use Vim, and it has a notoriously hard learning curve.
I've used Vim for almost a decade, and even if I'm not in Vim every day, the concepts of modal editing and keyboard-based navigation have transferred over into everything I do on the computer. Learning Vim is worth doing!
In this edition of the Bytesized newsletter, I'll cover both how to learn Vim, by going through some great tutorials and long-form pieces on how to think about modal editing, as well as some batteries-included configurations and plugins to have a great setup quickly. The Vim ecosystem is incredibly active and there's a ton of great developer experience improvements to be made over Vim's default setup as well, so if you're using Vim, you'll still get a ton out of this newsletter. Let's dig in!
Learn Vim, fast
How to Learn Vim: A Four Week Plan
Peter Jang offers a structured four-week plan to learn the fundamentals of Vim:
- Week 1: Complete vimtutor once a day, every day
- Week 2: Use Vim with minimal config, no plugins
- Week 3: Use Vim with minimal plugins
- Week 4: Compose Vim commands with verbs and nouns
VimTricks – weekly tips, tricks, guides, plugins, videos, screencasts, and more – all about Vim
VimTricks is a newsletter covering Vim tricks and plugins. Each week, you get a new Vim command, tip, or hack on how to work inside of Vim more effectively. Even if I'm not using Vim and I'm experimenting with a new editor or tool, I still try to catch up with VimTricks every week – it's a great read!
Learn Vim For the Last Time: A Tutorial and Primer
Daniel Missler's blog has a comprehensive (and up-to-date) reference to Vim, covering both the basics – working with files, changing/deleting text, etc., and more advanced topics, like repeating commands, macros. Of particular note is the section on Vim's editing language – see the video "Mastering the Vim Language" later in the newsletter for more on this.
vim.so: Learn and Master Vim faster with interactive exercises
Kenneth Cassel is building an interactive online Vim course that's available for just $8 at an early-bird discount.
A huge part of Vim's culture is sharing your configuration. The rise of GitHub has made this super easy: there's a ton of batteries-included Vim configurations that you can install in minutes to completely change (and hopefully enhance) your Vim workflow. Here's some of the more popular ones:
Watch Vim in action
How to Configure Vim like VSCode
Ben Awad covers his configuration to setup Vim like VSCode, including a file explorer, type-ahead suggestions, and more.
THE PERFECT VIM CONFIGURATION
Sebastian Karlsson dives into his
vimrc (the Vim configuration file), how it works, and how to install it for yourself.
Mastering the Vim Language
Chris Toomey covers Vim's editor language – a dense mapping of text objects, nouns, and verbs – that allow you to think about inserting and editing text in a way that many other editors simply can't do.
What is Neovim, and why should you care?
Neovim is an open-source project to modernize Vim and Vim's modal editing for a new generation of programmers. In this video, the MinuteVimTricks YouTube channel covers why Neovim matters for Vim developers, and why it may be worth switching to.
My favorite plugins
Like I said at the beginning of the email, I've been using Vim for almost a decade. Since this newsletter is getting a bit long, I narrowed down my choice picks to just three – the plugins I can't live without when I'm in Vim.
syntastic is a syntax checking plugin for Vim. If you've only worked with VSCode or other IDEs (integrated development environments), you might be surprised to learn that Vim ships without any sort of syntax checking! This plugin hooks into your language's checker tools (e.g.
gcc) and renders potential code errors right in your editor.
vim-airline was one of the first plugins I used to make my Vim installation look good. It updates Vim's tabline (the solid bar across the bottom of Vim's UI) with better colors, as well as the ability to customize it with information from other plugins, or from your own custom scripts.
ctrlp is a classic fuzzy file finder for Vim, used to quickly look up files in a project. This keyboard-based file finder became extremely popular via the editor TextMate, and this project seeks to bring it to Vim. Just type
<CTRL>-p (or whatever you customize it to), write a few characters of the file you're looking for, and press
enter. So easy!
Liked this issue? Good news—Bytesized's theme this month is editors. We'll be looking at text editors, tools for thought, and how to be more productive this year as we build software. See you next week!
Bytesized is a weekly newsletter exploring important ideas for developers. Join us on our Discord server 👋