How do I enable automatic folding in Vim? set foldmethod=syntax
doesn't seem to do much of anything.

- 17,502
- 10
- 52
- 59
4 Answers
To allow folds based on syntax add something like the following to your .vimrc
:
set foldmethod=syntax
set foldlevelstart=1
let javaScript_fold=1 " JavaScript
let perl_fold=1 " Perl
let php_folding=1 " PHP
let r_syntax_folding=1 " R
let ruby_fold=1 " Ruby
let sh_fold_enabled=1 " sh
let vimsyn_folding='af' " Vim script
let xml_syntax_folding=1 " XML
Syntax based folding is defined in the syntax files of the language which are located in $VIM/syntax
or /usr/share/vim/vimXX/syntax/
. But some languages do not have folding rules built into their syntax files; for example Python. For those languages you need to download something from http://vim.sf.net that does folds. Otherwise you will need to use folds based on indents. To do this effectively you will likely want to add the following to your .vimrc
file:
set foldmethod=indent
set foldnestmax=2
Other kinds of folding
There are 6 types of folds:
manual manually define folds
indent more indent means a higher fold level
expr specify an expression to define folds
syntax folds defined by syntax highlighting
diff folds for unchanged text
marker folds defined by markers in the text
Personally, I only use syntax folds. Usually, I just want to fold the method and not fold every indent level. Inconsistent indenting and weirdly formatted legacy code at work often makes indent folding difficult or impossible. Adding marks to the document is tedious and people who do not use Vim will not maintain them when they edit the document. Manual folds work great until someone edits your code in source control and all your folds are now in the wrong place.
More reading
- See
:help fold-methods
to learn the details of different fold methods. - See
:help folding
to learn the keyboard commands for manipulate folds. - See
:help folds
for help on the entire topic of folding.

- 28,495
- 9
- 107
- 102

- 17,502
- 10
- 52
- 59
-
10Did you really type all this within a minute of the question being posted? +1 for clarity, detail, and speed! – Cascabel Jan 25 '11 at 03:54
-
Thanks for sharing of your experience! Don't you know how to enable C++ folding? – Vitaly Isaev Mar 17 '14 at 08:00
-
For reference: Tested that C/C++ don't need additional `let ...=1` command, only `set foldmethod=syntax` is enough. i.e. some languages don't need a `let` command. – Johnny Wong Nov 01 '19 at 09:28
-
What would be the `let` setting for permanent JSON folding? I cannot find it anywhere. – Serge Stroobandt Apr 13 '21 at 11:51
JavaScript folding didn't work for me either. I found out when I did set syntax=javaScript (with a capital S), it suddenly worked.

- 473
- 3
- 15
-
1hehe i did that and all over sudden colors just vanished, guess it's not for everyone. :) `vim version 8`. – ArchNoob Feb 10 '17 at 10:25
-
At first I tried that but it did not fold anything and took away syntax highlight. Then I set back syntax=javascript and suddenly all my functions appear folded. Weird. – elig May 08 '19 at 14:08
Tried all of the solutions here and none worked with NeoVim v0.3.1 Until I found the vim-javascript plugin and folding started to work.

- 645
- 5
- 11
-
This; additionally, I had to do `set syntax=javaScript` for Neovim to actually detect JavaScript, then the folds immediately were activated (because I already had `set foldmethod=syntax` in my `init.vim` file, I suppose). Now onto putting this in the `init.vim` file, but only in the case where JS files are detected. – Alexandre Feb 03 '22 at 00:27
The way to enable folding in new versions of Vim has changed (I'm using vim 7.4). Now you should create the file ~/.vim/ftplugin/javascript.vim
(on linux) and add your code folding instructions as explained in Eric Johnson's answer. File type detection and loading plugins for specific file types must be enabled by putting this into your .vimrc
:
filetype plugin on

- 451
- 4
- 6