Vim documentation: usr_05
*usr_05.txt* For Vim version 8.0. 最近更新: 2017年8月
VIM 用户手册 - by Bram Moolenaar
译者: Nek_in, tocer http://vimcdoc.sf.net
选项设置
Vim 可以按你的需要进行设置。本章告诉你怎样使 Vim 用你指定的选项启动,怎样增加
插件以增强 Vim 的功能;以及怎样进行宏定义。
|05.1| vimrc 文件
|05.2| vimrc 示例解释
|05.3| 简单键盘映射
|05.4| 添加软件包
|05.5| 添加插件
|05.6| 添加帮助
|05.7| 选项窗口
|05.8| 常用选项
下一章: |usr_06.txt| 使用语法高亮
前一章: |usr_04.txt| 做小改动
目录: |usr_toc.txt|
==============================================================================
*05.1* vimrc 文件 *vimrc-intro*
可能你已经厌倦了输入那些经常用到的命令了。要让 Vim 用你习惯的设置启动,你可以
把这些设置写到一个叫 vimrc 的文件中。Vim 会在启动的时候执行这个文件里的命令。
如果你已经有 vimrc 文件 (例如,系统管理员已经为你配置好了),可以这样编辑它: >
:edit $MYVIMRC
如果你还没有 vimrc 文件,请参考 |vimrc| 一节看看你应该在什么地方创建该文件。另
外 ":version" 命令能告诉你 vim 要查找的 "用户 vimrc 文件" 的名字。
对于 Unix 和 Macintosh 系统,总是使用而且也推荐使用如下文件:
~/.vimrc ~
对于 MS-DOS 和 MS-Windows,可以使用下面其中一个文件:
$HOME/_vimrc ~
$VIM/_vimrc ~
vimrc 文件可以包含任何冒号命令。最简单的是设置选项命令。例如,如果你想 Vim 启
动的时候始终开启 'incsearch' 选项,可以在你的 vimrc 文件中加上:
>
set incsearch
要使这个命令生效,你需要重启动 Vim。后面我们还会学到如何不退出 Vim 就能让它生
效。
这一章只解释最基本的东西。想了解更多关于 Vim 脚本的知识,请参见 |usr_41.txt|。
==============================================================================
*05.2* vimrc 示例解释 *vimrc_example.vim*
在第一章中,我们曾经介绍过怎样用 vimrc 示例文件 (包括在 Vim 发布中) 使 Vim 以
非 vi 兼容模式启动 (参见 |not-compatible|)。这个文件可以在这里找到:
$VIMRUNTIME/vimrc_example.vim ~
我们在这一节中介绍这个文件中用到的一些命令。这会对你自行参数设置有一定的帮助。
但我们不会介绍所有的内容。你需要用 ":help" 获得更多的帮助。
>
set nocompatible
就像第一章所述,本手册解释在改进的方式下工作的 Vim,因此与 Vi 不完全兼容。要关
闭 'compatible' 选项,'nocompatible' 可以用于完成这个功能。
>
set backspace=indent,eol,start
这指明在插入模式下在哪里允许 <BS> 删除光标前面的字符。逗号分隔的三个值分别指:
行首的空白字符,换行符和插入模式开始处之前的字符。
>
set autoindent
这使 Vim 在启动一个新行的时候使用与前一行一样的缩进。就是说,新行前面会有同样
多的空白字符。启动新行是指用 <Enter> 换行,在普通模式下执行 "o" 命令等情况。
>
if has("vms")
set nobackup
else
set backup
endif
这告诉 Vim 当覆盖一个文件的时候保留一个备份。但 VMS 系统除外,因为 VMS 系统会
自动产生备份文件。备份文件的名称是在原来的文件名上加上 "~" 字符。参见 |07.4|
>
set history=50
这个命令保存 50 个命令和 50 个查找模式的历史。如果你想 Vim 记住多些或者少些命
令,可以把这个数改成其它值。
>
set ruler
总在 Vim 窗口的右下角显示当前光标位置。
>
set showcmd
在 Vim 窗口右下角,标尺的右边显示未完成的命令。例如,当你输入 "2f",Vim 在等
你输入要查找的字符并且显示 "2f"。当你再输入 w,"2fw" 命令被执行,"2f" 自动消
失。
+-------------------------------------------------+
|text in the Vim window |
|~ |
|~ |
|-- VISUAL -- 2f 43,8 17% |
+-------------------------------------------------+
^^^^^^^^^^^ ^^^^^^^^ ^^^^^^^^^^
'showmode' 'showcmd' 'ruler'
>
set incsearch
在输入部分查找模式时显示相应的匹配点。
>
map Q gq
这定义一个键映射。下一节会介绍更多的相关内容。这将定义 "Q" 命令用来完成与 "gq"
操作符相同的功能,这是在 Vim 5.0 版前 "Q" 命令的作用。如果没有设置这个映射,
"Q" 会启动 Ex 模式,这也许不是你想要的情况。
>
vnoremap _g y:exe "grep /" . escape(@", '\\/') . "/ *.c *.h"<CR>
这个映射在可视模式下拷贝已选择的文本并在 C 文件中查找它。这是一个复杂映射。你
可以看到该映射可以被用来执行相当复杂的操作。但其本质依然是一个命令序列而已,
与你直接输入没有什么两样。
>
if &t_Co > 2 || has("gui_running")
syntax on
set hlsearch
endif
这激活语法高亮功能,但仅在有色彩的时候才有效。而 'hlsearch' 选项告诉 Vim 高亮
上次查找模式匹配的地方。"if" 命令在设置选项的时候非常有用,它使设置命令在某些
条件下才执行。更多的内容请参见 |usr_41.txt|。
*vimrc-filetype* >
filetype plugin indent on
这启动三个非常灵巧的机制:
1. 文件类型探测
当你开始编辑一个文件的时候,Vim 会试图确定这个文件的类型。当编辑 "main.c"
时,Vim 会根据扩展名 ".c" 认为这是一个 C 源文件。当你编辑一个文件前面是
"#!/bin/sh" 的文件时,Vim 会把它认作 "sh" 文件。文件类型探测用于语法高亮
和以下另两项。请参见 |filetypes|。
2. 使用文件类型相关的插件
不同的文件需要不同的选项支持。例如,当你编辑一个 "c" 文件,用 'cindent' 选
项来自动缩进就非常有用。这些文件类型相关的选项在 Vim 中是通过文件类型插件
来实现的。你也可以加入自己的插件,请参见 |write-filetype-plugin|。
3. 使用缩进文件
当编辑程序的时候,行缩进通常可以被自动决定。Vim 用不同的策略处理不同的文件
类型。请参见 |:filetype-indent-on| 和 'indentexpr'。
>
autocmd FileType text setlocal textwidth=78
这使 Vim 在一行长于 78 个字符的时候自动换行,但仅对纯文本文件中有效。这里包括
两个部分。其中 "autocmd FileType text" 定义个自动命令,表示当文件类型被设置为
"text" 的时候,后面的命令自动执行。"setlocal textwidth=78" 设置 'textwidth' 选
项为 78,但仅对本文件有效。
*restore-cursor* >
autocmd BufReadPost *
\ if line("'\"") > 1 && line("'\"") <= line("$") |
\ exe "normal! g`\"" |
\ endif
这是又一个自动命令。这回它设置为在读入任何文件之后自动执行。后面那堆复杂的东西
检查 '" 标记是否已被定义,如果是,则跳转到该标记。行首的反斜杠用于把所有语句连
接成一行。这可以避免一行写得太长,
请参见 |line-continuation|。这只在 Vim 脚本文件中有效,在命令行中无效。
==============================================================================
*05.3* 简单键盘映射
映射可以使你把一系列 Vim 命令绑定为一个单独的键。假设你要用一个大括号将一个特
定的单词括起来。例如,把 "amount" 变成 "{amount}"。用 ":map" 命令,就可以让 F5
来完成这个工作。命令如下:
>
:map <F5> i{<Esc>ea}<Esc>
<
备注:
在输入这个命令时,<F5> 要用四个字符表示。相似地,输入 <Esc> 不是直接按
<Esc> 键,而是输入五个字符。读这份手册时请注意这些区别!
让我们来分解一下这个命令:
<F5> F5 功能键。这是命令的触发器。当这个键被按下时,相应的命令即被
执行。
i{<Esc> 插入 { 字符。<Esc> 键用于退出插入模式。
e 移动到词尾。
a}<Esc> 插入 } 到单词尾。
执行 ":map" 命令后,要在单词两端加上 {},只需要移到单词的第一个字符上并按 F5。
在这个例子中,触发器是单独一个键;它还可以是任何字符串。但若你使用一个已经存在
的 Vim 命令,该命令将不再有效。最好避免出现这种情况。
一个可用于映射的键是反斜杠。因为你很可能想定义多个映射,那就加上另一个字
符。你可以映射 "\p" 为在单词两端加圆括号,而映射 "\c" 为加花括号,例如:
>
:map \p i(<Esc>ea)<Esc>
:map \c i{<Esc>ea}<Esc>
你需要在敲入 \ 后,立即敲入 p,以便 Vim 知道它们组成一个命令。
":map" 命令 (无参数) 列出当前已定义的映射,至少会包括普通模式下的那些。更多的
内容参见 |40.1|。
==============================================================================
*05.4* 添加软件包 *add-package* *matchit-install*
软件包是一组可加入 Vim 的文件。有两种软件包: 可选的和启动时自动载入的。
Vim 发布提供了一些软件包供你选用。例如 matchit 插件。此插件使 ”%“ 命令跳转到匹
配的 HTML 标签、Vim 脚本中的 if/else/endif 等。很有用,但不后向兼容 (这是为什
么缺省没有打开)。
要开始用 matchit 插件,在 vimrc 文件中加入一行: >
packadd! matchit
就这样!重启 Vim 后可以找到此插件的帮助: >
:help matchit
这之所以能工作,是因为 `:packadd` 载入插件时,同时把软件包目录加入
'runtimepath',这样就能找到帮助文件了。
网上有多个地方可以找到软件包。它们通常以归档或版本库形式出现。如果是归档,可以
采用以下步骤:
1. 建立软件包目录: >
mkdir -p ~/.vim/pack/fancy
< "fancy" 可以是任何你喜欢的名字。要能描述你的软件包。
2. 在该目录里解压归档。假定归档的顶层目录是 "start": >
cd ~/.vim/pack/fancy
unzip /tmp/fancy.zip
< 如果归档的目录结构不同,确保最终的路径像这样:
~/.vim/pack/fancy/start/fancytext/plugin/fancy.vim ~
这里 "fancytext" 是软件包名,这可以是任何其它名字。
关于软件包的详情可见: |packages|。
==============================================================================
*05.5* 添加插件 *add-plugin* *plugin*
Vim 可以通过插件增强功能。插件其实是一个当 Vim 启动的时候能被自动执行的脚本。
简单地把插件放到你 Vim 的 plugin 目录中就可以使它生效。
{仅当 Vim 编译时加入 |+eval| 特性时才有效}
Vim 中有两种插件:
全局插件: 用于所有类型的文件
文件类型插件: 仅用于特定类型的文件
我们将先讨论全局插件,然后涉及文件类型插件 |add-filetype-plugin|。
全 局 插 件 *standard-plugin*
当你启动 Vim,它会自动加载一些插件。你不需要为此做任何事。这些插件增加一些很多
人想用的,但由 Vim 脚本实现而非编译进 Vim 中的功能。你可以在帮助索引中找到这些
插件: |standard-plugin-list|。还可以参照 |load-plugins|。
*add-global-plugin*
你可以加入一个全局插件使得某些功能在你每次使用 Vim 时都被开启。添加一个全局插
件只要两步:
1. 获得一个插件的拷贝
2. 把它塞进合适的目录
获 得 一 个 全 局 插 件
在什么地方可以找到插件?
- 有一些与 Vim 一起发布,你可以在 $VIMRUNTIME/macros 目录或其子目录中找到。
- 从网上下载,http://www.vim.org 收集了很多。
- 在 Vim 的邮件列表中找: |maillist|。
- 自己写一个,参见 |write-plugin|。
某些插件被打包在 vimball 中,参见 |vimball|。
某些插件可以自动更新,参见 |getscript|。
使 用 一 个 全 局 插 件
首先阅读插件包括的说明文字,看看有没有什么特殊的限制。然后拷贝到你的插件目录:
系统 插件目录 ~
Unix ~/.vim/plugin/
PC 和 OS/2 $HOME/vimfiles/plugin 或 $VIM/vimfiles/plugin
Amiga s:vimfiles/plugin
Macintosh $VIM:vimfiles:plugin
RISC-OS Choices:vimfiles.plugin
以 Unix 系统为例 (假设你还没有 plugin 目录):
>
mkdir ~/.vim
mkdir ~/.vim/plugin
cp /tmp/yourplugin.vim ~/.vim/plugin
就是这样了!现在你可以用这个插件定义的命令了。
除了把这些插件直接放进 plugin/ 目录以外,还可以更好地组织一下,把它们放进
plugin 的单独的子目录中。例如,可以考虑把所有 Perl 插件放置在
"~/.vim/plugin/perl/*.vim"
文件类型插件 *add-filetype-plugin* *ftplugins*
Vim 的发布中包括一套针对不同文件类型的插件。你可以用如下命令启用它们:
>
:filetype plugin on
这样就行了!参阅 |vimrc-filetype|。
如果你缺少某种文件类型的插件,或者你找到一个更好的,你可以自行添加一个。这也只
需两步:
1. 获取一个插件的拷贝
2. 塞到合适的目录。
取 得 文 件 类 型 插 件
你可以在找全局插件的相同地方找到文件类型插件。注意一下插件有没有注明文件类型,
据此你可以知道这个插件是全局的还是文件类型相关的。在 $VIMRUNTIME/macros 中的是
全局插件;文件类型插件在 $VIMRUNTIME/ftplugin 中。
使 用 文 件 类 型 插 件 *ftplugin-name*
你可以通过把插件文件放到合适的目录中来增加一个插件。目录的名字与前面提过的全局
插件的位置一样,但最后一级目录是 "ftplugin"。假设你找到一个用于 "stuff" 文件类
型的插件,而且你的系统是 Unix。那么,你可以把这个文件用如下命令移入 ftplugin
目录:
>
mv thefile ~/.vim/ftplugin/stuff.vim
如果这个文件已经存在,你可以检查一下两个插件有没有冲突。如果没有,你可以用另一
个名字:
>
mv thefile ~/.vim/ftplugin/stuff_too.vim
这里,下划线用来分开文件类型和其它部分 (这些部分可以由任意字符组成)。但如果你
用 "otherstuff.vim" 就不行了。那是用于 "otherstuff" 类型的文件的。
在 MS-DOS 上不能使用长文件名。如果你增加第二个插件,而这个插件超过 6 个字符,
你就没法用了。你可以通过使用另一层目录来解决这个问题:
>
mkdir $VIM/vimfiles/ftplugin/fortran
copy thefile $VIM/vimfiles/ftplugin/fortran/too.vim
总的来说,一个文件类型相关的插件的名称是:
>
ftplugin/<filetype>.vim
ftplugin/<filetype>_<name>.vim
ftplugin/<filetype>/<name>.vim
这里 "<name>" 可以是任何你喜欢的名字。例如,在 Unix 上,"stuff" 文件类型的插件
可以是:
>
~/.vim/ftplugin/stuff.vim
~/.vim/ftplugin/stuff_def.vim
~/.vim/ftplugin/stuff/header.vim
这里, <filetype> 部分是相应文件类型的名称。只有对应文件类型的文件才会用这个插
件内的设置。插件的 <name> 部分则不重要,你可以对同一个文件类型使用多个插件。
注意 插件必须以 ".vim" 结尾。
请进一步阅读:
|filetype-plugins| 文件类型插件的文档和有关如何避免映射引起的问题。
|load-plugins| 全局插件的启动时间。
|ftplugin-overrule| 控制全局文件类型插件的选项。
|write-plugin| 如何写插件。
|plugin-details| 关于如何使用插件的信息或者当你的插件不工作的时候如何处
理。
|new-filetype| 如果检测新文件类型。
==============================================================================
*05.6* 添加帮助 *add-local-help*
如果幸运的话,你安装的插件还会包括帮助文件。我们这里解释如何安装这个帮助文件,
以便你能方便地获得新插件的帮助。
我们以 "doit.vim" 插件为例。这个插件有一个文档: "doit.txt"。我们先来把该插
件拷贝到合适的位置。这次,我们在 Vim 内完成这个工作。(如果某些目录已经存在你可
以省略一些 "mkdir" 命令。) >
:!mkdir ~/.vim
:!mkdir ~/.vim/plugin
:!cp /tmp/doit.vim ~/.vim/plugin
"cp" 命令是基于 Unix 的,MS-DOS 上你可以用 "copy"。
现在在某个 'runtimepath' 目录中建立一个 doc 目录。
>
:!mkdir ~/.vim/doc
再把帮助文件拷贝进去:
>
:!cp /tmp/doit.txt ~/.vim/doc
现在开始玩技巧了,怎样使 Vim 允许你跳转到新的主题上?用 |:helptags| 命令产生一
个本地的 tags 文件即可:
>
:helptags ~/.vim/doc
现在,你可以用这个命令
>
:help doit
来获得 "doit" 的帮助了。显示你刚才加上的帮助文件。在使用如下命令的时候,可以看
见一个新的条目: >
:help local-additions
本地帮助的标题行被自动的加入到该节了。在那里你可以看到 Vim 添加了那些本地的帮
助文件。你还可以从这里跳转到新的帮助中。
要写一个本地帮助文件,请参考 |write-local-help|。
==============================================================================
*05.7* 选项窗口
如果要找一个选项,你可以在这里寻找帮助: |options|。另一个方法是用如下命令:
>
:options
这会打开一个新窗口,其中给出一个选项的列表,并对每个选项提供一行解释。这些选项
根据种类分组。将光标移到一个主题上然后按 <Enter> 就可以跳转到那里。再按一下
<Enter> 或者 CTRL-O 就可以跳回来。
你可以通过这个窗口改变一个选项的值。例如,移到 "displaying text" 主题。然后把
光标下移到这一行:
set wrap nowrap ~
当你在上面键入回车,这行会改变为:
set nowrap wrap ~
现在,这个选项被关闭了。
这行的上方是对这个选项的简要描述。将光标向上移动一行,然后按 <Enter>,你可以跳
转到 'wrap' 的完整帮助,再用 CTRL-O 可以跳回来。
对于那些值为数值或者字符串的选项,你可以编辑它的值,然后按 <Enter> 来启用该
值。例如,把光标移动到下面这行:
set so=0 ~
用 $ 移到行尾,再用 "r5" 命令修改为五,然后按 <Enter> 使修改生效。现在如果你移
动一下光标,你会发现在你的光标移到窗口边界前,你的文字就开始滚动了。这就是选项
'scrolloff' 完成的功能: 它指定在距离边界多远的地方开始滚动文字。
==============================================================================
*05.8* 常用选项
Vim 中有很多选项。大部分你很少用得上。我们在这个介绍一些常用的。别忘了你可以通
过 ":help" 命令获得更多的帮助。方法是在选项命令前后加上单引号,例如:
>
:help 'wrap'
如果你搞乱了一个选项,你可以通过在选项后加上一个 & 号把它恢复到默认值。例如:
>
:set iskeyword&
禁 止 回 绕 行
Vim 通常会对长行自动回绕,以便你可以看见所有的文字。但有时最好还是能让文字在一
行中显示完。这样,你需要左右移动才能看到一整行。以下命令可以关闭行的回绕:
>
:set nowrap
当你移动到那些不能显示的文字上,Vim 会自动向右滚动让你看到后面的文字,要一次滚
动十个字符,这样就行了:
>
:set sidescroll=10
这个命令不改变文件中的文本,只改变显示方式。
移 动 命 令 换 行
很多命令只能在一行中移动。你可以通过 'whichwrap' 选项改变它。如下命令把这个选
项设为默认值:
>
:set whichwrap=b,s
这样,当光标处于行首时用 <BS> 键可以回到前一行的结尾;当处于行尾时用 <Space>
键可以移动到下一行的行首。
要允许 <Left> 和 <Right> 键也能这样,可以用这个命令:
>
set whichwrap=b,s,<,>
这只在普通模式中有效,要在插入模式中使 <Left> 和 <Right> 也有效,可以:
>
:set whichwrap=b,s,<,>,[,]
还有一些可以用的标志位,参见 'whichwrap'。
显 示 TAB 键
文件中有 TAB 键的时候,你是看不见的。要把它显示出来:
>
:set list
现在 TAB 键显示为 ^I,而 $显示在每行的结尾,以便你能找到可能会被你忽略的空白字
符在哪里。
这样做的一个缺点是在有很多 TAB 的时候看起来很丑。如果你使用一个有颜色的终
端,或者使用 GUI 模式,Vim 可以用高亮显示空格和 TAB。使用 'listchars' 选项:
>
:set listchars=tab:>-,trail:-
现在,TAB 会被显示成 ">---" ("-" 的个数不定) 而行尾多余的空白字符显示成 "-"。
看起来好多了,是吧?
关 键 字
'iskeyword' 选项指定哪些字母可以出现在一个单词中:
>
:set iskeyword
< iskeyword=@,48-57,_,192-255 ~
"@" 表示所有字母。"48-57" 表示 ASCII 字符 48-57 ,即数字 0 到 9。"192-255" 是
可显示的拉丁字符。
有时你希望横线也是关键字,以便 "w" 命令会把 "upper-case" 看作是一个单词。
你可以这样做:
>
:set iskeyword+=-
:set iskeyword
< iskeyword=@,48-57,_,192-255,- ~
看一下新的值,你会发现 Vim 自动在 "-" 前面加了一个逗号。
要从中去掉一个字符,用 "-="。例如要排除下划线:
>
:set iskeyword-=_
:set iskeyword
< iskeyword=@,48-57,192-255,- ~
这回,逗号又自动被删除了。
显 示 消 息 的 空 间
当 Vim 启动的时候,在屏幕底部有一行被用于显示消息。当消息很长的时候,多余的部
分会被截断。这样你只能看到一部分。或者文字自动滚动,你要按 <Enter> 来继续。你
可以给 'cmdheight' 选项赋一个值,用来设定显示消息所用的行数。例如:
>
:set cmdheight=3
这样意味着你用于编辑文字的空间少了,所以这实际上是一种折衷。
==============================================================================
下一章: |usr_06.txt| 使用语法高亮