Vim Color Schemes: How to Configure

July 11, 2024

Introduction

Vim color schemes are a useful feature of this popular text editor. They allow for practical syntax highlighting and user interface customization.

You can change the color schemes included in the software package or install user-made color schemes. The software also allows you to configure the colors of individual elements manually.

In this tutorial, learn how to use and set Vim color schemes.

Vim Color Schemes: How to Configure

Prerequisites

Note: This guide is also applicable to NeoVim, which extends Vim with additional features. However, NeoVim instances usually utilize an init.vim file instead of a .vimrc for configuration settings. The init.vim file is commonly located at ~/.config/nvim/init.vim.

Built-in Vim Color Schemes

When you install Vim, it selects a standard color scheme based on your terminal's appearance settings. 

The text editor uses a default scheme, which depends on whether a light or dark terminal is used. The default Vim color scheme in a light terminal is peachpuff. In a dark terminal, the initial color scheme is ron.

How to Install a New Vim Color Scheme 

Two main ways to install a new Vim color scheme are manually or via a plugin. The following text elaborates on both methods.

Download Vim Color Scheme Manually 

A wide variety of user-made color schemes may better suit your needs than the default options. Find and download schemes from GitHub or websites such as vimcolorschemes.

To get new color schemes manually, take the following steps:

1. Access the website with the color schemes. In this case, it's GitHub.

2. Scroll down until you find the scheme that works for you. In this example, it's gruvbox.

Gruvebox color scheme repository on GitHub

3. Click the morhetz/gruvbox link.

4. Click the colors directory. This is where the color scheme files are stored.

Click on the colors directory

5. Inside the colors directory, find and click the gruvbox.vim file.

Click on the gruvbox.vim file

6. Click the Raw button in the top-right corner.

Click on the Raw button

7. Note the URL in your browser's address bar. It is the direct link to the raw file.

Vim gruvbox color scheme URL

8. Create the /.vim/colors directory using the mkdir command:

mkdir -p ~/.vim/colors

9. Use wget to download and install the color scheme. The syntax is:

wget [URL] -O ~/.vim/colors/[scheme_name].vim

For example, in this case:

wget https://raw.githubusercontent.com/morhetz/gruvbox/master/colors/gruvbox.vim -O ~/.vim/colors/gruvbox.vim
Terminal output for wget

The command consists of:

  • wget. A command-line utility used to download files from the internet.
  • https://raw.githubusercontent.com/morhetz/gruvbox/master/colors/gruvbox.vim. The URL of the file you want to download.
  • -O. Option which tells wget to save the downloaded file with a specific name and path.
  • ~/.vim/colors/gruvbox.vim. The path and name where the downloaded file is saved.
    • ~/.vim/colors/ is the directory where Vim color schemes are stored.
  • gruvbox.vim. The name of the file. In the example, the file is saved as gruvbox.vim in the ~/.vim/colors/ directory.

10. Verify the download with the ls command:

ls ~/.vim/colors
terminal output for ls ~/.vim/colors

11. Open Vim.

12. Access the command mode by pressing the Escape key and typing :

vim command mode

13. Run the following and press Enter:

colorscheme gruvbox
Vim with changed color

Vim changes color according to the new scheme. Note that the change lasts only during the current session.

Install Vim Color Scheme Using Plugins

Installing Vim color schemes using plugins is more convenient, especially if you use a plugin manager. One popular Vim plugin manager is vim-plug. Take the following steps to install Vim color schemes using vim-plug.

1. Access GitHub.

2. Search for and click vim-plug.

vim-plug on GitHub

3. Scroll down to the Installation section and select Click to see the instructions.

vim-plug Installation section

4. Copy the code starting with curl and paste it into the terminal to install vim-plug.

curl -fLo ~/.vim/autoload/plug.vim --create-dirs \
https://raw.githubusercontent.com/junegunn/vim-plug/master/plug.vim
curl terminal output

5. Open the .vimrc file:

vim ~/.vimrc

6. Add the following lines to install the color scheme plugin. For example, to install the gruvbox color scheme

call plug#begin('~/.vim/plugged')
Plug 'morhetz/gruvbox'
call plug#end()

colorscheme gruvbox
edit ~/.vimrc in Vim

7. Open Vim and run the following command to install the plugins defined in your .vimrc

PlugInstall
PlugInstall vim output

After PlugInstall finishes, the gruvbox color scheme is applied. If it is not, set it by running:

colorscheme gruvbox

View Installed Vim Color Schemes

To see a list of ready-to-use themes, open any document using the Vim editor and use the following instruction:

colorscheme [space] [Ctrl+d]

The output shows a list of Vim color schemes:

colorscheme Vim output shows installed Vim color schemes

How to Change Vim Color Scheme

There are two ways to change Vim colors: changing the color scheme or changing individual colors. The following text elaborates on both methods.

Change Vim Color Scheme 

After prompting Vim to display a color scheme list, change the design until you find a suitable one.

To change the Vim color scheme, use the following:

colorscheme [colorscheme_name]

You can also use an abbreviation:

colo [colorscheme_name]

For example, to switch to the color scheme blue, use:

colorscheme blue

Here are just some examples of how the color schemes differ:

Vim color schemes

Manually Change Vim Colors

Another way to customize Vim colors is to configure the color settings manually.

The syntax is:

highlight [Group] [key=value]

The command consists of:

  • highlight. Defines or modifies the highlighting attributes of syntax groups.
  • [Group]. Specifies the name of the syntax group you want to highlight. Syntax groups are predefined collections of text elements in Vim (e.g., comment, keyword, string, error message, non-text, etc.).
  • [key=value]. The attributes you set for the specified group. You can set multiple attributes by separating them with spaces. Common attributes include:
    • cterm. Attributes for terminals that support color.
    • ctermfg. Foreground color for terminals.
    • ctermbg. Background color for terminals.
    • gui. Attributes for graphical Vim (GVim).
    • guifg. Foreground color for GVim.
    • guibg, Background color for GVim.
    • guiattr. Additional GUI attributes (e.g., bold, underline, etc.).

When specifying the values for ctermfg, ctermbg/guifg, and guibg, use standard color names, their prescribed numbers, or hex values (only in the GUI).

However, cterm and gui are not used with color values. Instead, the values you use for these highlight keys include bold, italic, underline, reverse, and none.

Note: You can substitute highlight with hi for short.

The following example shows how the highlight command works.

For instance, the file has the default color scheme in Vim:

default Vim color scheme

Set all Normal text to red (foreground) and the background color to black. Type the following:

hi Normal ctermfg=Red ctermbg=Black

Press Enter, and the colors automatically change, as in the image below.

vim changed colors

How to Set Default Vim Color Scheme

Changes made to the color settings are not permanent. Once you close Vim, the color scheme returns to the default settings.

To make the changes permanent, modify Vim's configuration file with the wanted color settings. Take the following steps:

1. Open the .vimrc file in Vim. If the file does not exist, this command creates it.

vim ~/.vimrc

2. Add the following line to set the default color scheme.

syntax on colorscheme [your_color_scheme]

The syntax on instructs Vim to highlight code syntax based on the file type. Different code elements (like keywords, comments, strings, etc.) are colored differently, making it easier to read and understand the code.

Test the command by choosing one color scheme. For instance, to set gruvbox as your default color scheme, add:

syntax on colorscheme gruvbox
syntax on colorscheme gruvbox

3. Save and exit the file.

Conclusion

This article showed how to set up and use default or custom Vim color schemes.

Next, learn important Vim commands.

Was this article helpful?
YesNo
Sara Zivanov
Sara Zivanov is a technical writer at phoenixNAP who is passionate about making high-tech concepts accessible to everyone. Her experience as a content writer and her background in Engineering and Project Management allows her to streamline complex processes and make them user-friendly through her content.
Next you should read
How to Save a File in Vi / Vim & Exit
September 22, 2022

Vim (Vi IMproved) is a well-known, open-source text editor for Linux or Unix systems. It is a powerful and...
Read more
How To Install Vim 8.2 on Ubuntu 18.04
September 29, 2022

VIM, known as the programmer's editor, is highly configurable and customizable. Also, it allows syntax...
Read more
22 Best Linux Text Editors for Programming & Coding
September 3, 2019

A text editor is an application that lets you type text. All Linux distributions come with built-in editors...
Read more
How to Cut, Copy and Paste in Vim / Vi
April 6, 2020

Complete guide on how to use crucial Vim commands - copying (yanking), cutting (deleting), and pasting...
Read more