Vim中的代码折叠的方法,除了diff
我都(试图)用过。总结下来最好用的还是网络上大家提及最少的marker
最好用。
-
indent
/syntax
这两种,属于全自动。看上去好用。但实际上,它常常会在你不想折叠的地方折叠而想折叠的地方它折叠不了(因为nesting设置起来很矛盾)。它还会托慢vim的速度,但这又是另一说了。 -
expr
这种,我只是浅尝了一下。纯手动定义语义来进行折叠。定义一个完美的折叠方式非常费事,但定义完了就是全自动。我也懒得深究。 -
manual
。在此之前是我用的最久的折叠方式。好处是你可以自己选取自己想要的段落用zf
就可以永久自定义一个折叠区了。删除光标所在的折叠区用zd
,递归删除zD
,全文删除折叠区zE
。在问题在于,它记录折叠区域的方式有问题。一旦我在文中有增减行数的行为,我修改处以下的所有折叠区都会乱(Vim估计是用的行号来记录的)。
而marker
其实就是一个用户显式定义折叠区边际的manual
模式。如果说manual
是vim在后台记录行数来确定折叠区起始和结束位置。marker
就是在文章/代码中用可见字符来标记。这个可见字符就是{{{n
和}}}n
(其中n
是一个代表foldlevel`的整数,可在嵌套折叠时使用,如果使用得当忽略这个也没什么问题)。
因为这种折叠自己可以显式定义边界,就不会出现manual
模式下那样修改上文打乱下文折叠的局面。
另外,marker
模式也是可以使用折叠快捷键的。
zf
创建折叠区。它会自动在你选择的区域在起始和结束的地方加上{{{
和}}}
。
- 如果是Vim认识的
filetype
的话,它还会自动注释这写折叠标记。 - 它不会用
{{{
把折叠起始行的内容框进去,而是在起始行行末添加标记。这样你起始行的的内容就会成为折叠区的“标题”。方便浏览全文。
比如,为func1函数定义做折叠的话:
// 原文
int func1() {
return 1;
}
// 选取func1,包含函数上下各一个空行,然后zf
/*{{{*/
int func1() {
return 1;
}
/*}}}*/
// 只选取func1,不包含空行,然后zf
int func1() {/*{{{*/
return a;
} /*}}}*/
// 如果func1上有注释,把注释也框选,然后zf
// returns 1{{{
int func1() {
return a;
} /*}}}*/
所有的折叠标记,只需要使用zE
或zd
或其他删除折叠区的快件键就可以删的不留痕迹。所以不用担心把代码分享给使用其他编辑器的同事时被唾弃。