Bootstrap

Linux系列讲解 —— VIM配置与美化

1. Vim基本配置

1.1 配置文件
vim的配置文件有两处,请根据实际情况选择修改哪个。

(1) 全局配置文件( /etc/vim/vimrc )
此文件的配置会对系统内所有用户有效,包括root用户。

(2) 单用户配置文件( /home/xxx/.vimrc )
此文件的配置只对用户xxx有效。这里xxx代表用户名,比如用户名是sun,则修改/home/sun/.vimrc。如果当前登录用户就是sun,也可以直接修改~/.vimrc,因为在linux系统中符号 ~ 等同于用户的家路径,按照此处例子即为/home/sun。

1.2 基本配置
vimrc文件的注释要以双引号 ( " ) 开头。

syntax on                     " 设置语法高亮                                                                                                                                                                              
set nu                        " 设置行数显示
set tabstop=4                 " 设置tab缩进长度为4空格
set autoindent                " 设置自动缩进,适用所有类型文件
set cindent                   " 针对C语言的自动缩进功能,在C语言的编程环境中,比autoindent更加精准
set list lcs=tab:\|\          " 设置tab提示符号为 "|",注意最后一个反斜杠后面要留有空格
set cc=0                      " 设置高亮的列,这里设置为0,代表关闭
set cursorline                " 突出显示当前行

基本配置后,效果如下图
在这里插入图片描述

2. 插件管理器vim-plug

vim可以安装插件来增加很多功能。这里推荐一个插件管理器vim-plug,用来安装各种插件,比自己在网上一个个找插件安装更加高效。项目的github地址:https://github.com/junegunn/vim-plug,上面有比较详细的介绍。

2.1 下载

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

如果下载时出现网络问题,可以在 /etc/hosts 中添加下面语句后,重新执行下载命令。

199.232.28.133 raw.githubusercontent.com

2.2 在vimrc中添加vim-plug的配置

添加如下内容:

call plug#begin()                 " vim-plug开始(必须)
Plug '插件'                       " 这里写插件名称,例如 Plug 'scrooloose/nerdtree'
call plug#end()                   " vim-plug结束(必须)

注:
(1) 上面这段必须要写在vimrc文件的开头,否则安装插件会有问题。
(2) vim-plug安装的插件默认都会放在 ~/.vim/plugged 中。开始语句的括号内可以指定安装路径,例如:call plug#begin(‘~/some/path/here’)。
(3) 需要添加的插件放到 call plug#begin()call plug#end() 之间。

2.3 vim-plug的使用

命令描述
PlugInstall [插件名] [线程数]安装插件。如果不指定插件名,则安装.vimrc中所有记录的插件。
PlugUpdate [插件名] [线程数]安装或更新插件
PlugClean删除所有插件。ps:如果只是哪个插件不想用了,可以直接在.vimrc中把它注释掉即可。
PlugUpgrade升级vim-plug
PlugStatus检查插件的状态
PlugDiff显示更新前后插件变更内容
PlugSnapshot [快照文件路径]生成用于恢复插件的当前快照的脚本。生成的快照文件会包含插件当前的 git commit id
恢复插件的方法: 在vim中source快照文件或直接执行vim -S snapshot.vim

下面演示几个命令:
请添加图片描述

有时候会出现下载插件超时的情况,这种情况可以把插件的下载地址更改为国内镜像地址 ( 国内镜像源请查看Git系列讲解(六):Git使用中的问题汇总 ),方法如下:

修改 ~/.vim/autoload/plug.vim
在这里插入图片描述

3 安装常用插件

3.1 NERDTree — 目录树

安装NERDTree后,vim就可以使用目录树(NERDTree)了。
在这里插入图片描述

1. NERDTree基本配置
下面是我在~/.vimrc中的配置,请依据自己情况进行配置。

Plug 'scrooloose/nerdtree'   " 放在语句 call plug#begin() 和 call plug#end() 之间

" 下面几行是配置NERDTree插件的,正常也可以不用配置,看自己需求。
autocmd VimEnter * NERDTree    " 打开文件后自动打开NERDTree
map <F2> :NERDTreeMirror<CR>   " 按键F2:映射其他标签页
map <F3> :NERDTreeToggle<CR>   " 按键F3:展开/收缩NERDTree
map f :NERDTreeFind<CR>        " 按键f:在NERDTree窗口中,将光标跳转到当前打开的文件上。
map 1 :tabp<CR>                " 按键1:切换到前一个标签页
map 2 :tabn<CR>                " 按键2:切换到后一个标签页

这里解释一下map :NERDTreeToggle<CR>语句:
map <F3>       代表F3按键
:NERDTreeToggle   代表末行模式下输入NERDTreeToggle
<CR>         代表换行

2. 安装
打开vim编辑器,在末行模式下输入命令PlugInstall后回车,等待安装完成即可。

3. NERDTree常用快捷键
NERDTree的官方帮助文档默认位置:~/.vim/bundle/nerdtree/doc/NERDTree.txt

(1) 文件打开,编辑窗口的切换 / 分割 / 关闭等:

快捷键作用
o 或 回车(光标在文件上时)打开文件,光标会跳转到新打开的窗口
go (光标在文件上时)打开文件,光标不会跳转到新打开的窗口
ctrl+w+w在各个窗口之间相互切换
ctrl+w+h向左侧窗口切换
ctrl+w+j向下侧窗口切换
ctrl+w+k向上侧窗口切换
ctrl+w+l (小写L)向右侧窗口切换
i水平分割出一个新窗口,并显示光标所在位置的文件内容,光标会跳转到新开窗口
gi与 i 不同处是光标不会跳转,依旧停留在nerdtree中
s垂直分割出一个新窗口,并显示光标所在位置的文件内容,光标会跳转到新开窗口
gs与 s 不同处是光标不会跳转,依旧停留在nerdtree中
光标在nerdtree窗口时,按q关闭nerdtree,或者使用.vimrc中设置的快捷键

在这里插入图片描述

(2) NERDTree窗口内部行为

快捷键作用
?打开帮助页面,再次按 ? 可以退出帮助页面。不退出也行,打开帮助页面后,目录树在帮助文字后面,往下翻就行。
m打开NERDTree菜单页,菜单页有很多实用功能,包括创建,删除,移动节点。还有在文件资源管理器打开当前节点等。

关闭菜单:按两次Esc键
在这里插入图片描述
o 或 回车(光标在目录上时)展开或收缩该目录
O(光标在目录上时)递归展开选中节点下的所有目录,目录级别多时很耗时,不建议使用。
x(光标在任意文件或目录上时)父目录收缩,光标跳回父目录处
X(光标在任意文件或目录上时)光标所在目录,其下所有子目录收缩。
I(大写i)显示/关闭隐藏文件
C切换NERDTree的根节点为光标所在路径
cd设置CWD为NERDTree中光标所在路径
CD切换NERDTree根节点为CWD路径,注意cd和CD是配合使用的。
u设置当前根节点的上一级为新的根节点
U设置当前根节点的上一级为新的根节点,但是维持原来目录打开的状态
p光标移动到父目录
P光标移动到当前nerdtree的根节点
G光标移动到当前nerdtree的最后一项
ctrl+j光标移动到下一个同级别节点
ctrl+k光标移动到上一个同级别节点
K根据当前光标所在文件或目录,移动光标到该文件或目录同等级的第一项
J根据当前光标所在文件或目录,移动光标到该文件或目录同等级的最后一项
L在nerdtree中,显示文件总行数。

在这里插入图片描述

(3) NERDTree常用命令:

快捷键作用
:NERDTree [<路径> | <书签>]新建并展开NERDTree,根节点为后面的路径或书签。若不指定路径或书签,则根节点默认为终端运行vim时的当前路径。
:NERDTreeClose关闭NERDTree
:NERDTreeToggle [<路径> | <书签>]切换NERDTree的展开和收缩。

注:
1.NERDTreeToggle默认展开的NERDTree,内容与上次收缩前一样。如果之前没有打开过NERDTree,则此时相当于命令NERDTree,打开时根节点默认为终端运行vim时的路径。
2.NERDTreeToggle也可以后接路径或书签,此时相当于命令NERDTree后接路径或书签(NERDTree关闭状态运行才有效)。
:NERDTreeMirror将其它标签页中的NERDTree镜像过来,有镜像关系的这些NERDTree,标签页上显示的NERDTree名称都是一样的(例如:NERD_tree_1),并且无论哪一个有变更,其他的NERDTree都会有一致性变化。

注:
1.上面的NERDTree命令相当于重新创建一个NERDTree实例,所以使用NERDTree命令会破坏镜像关系。
2.如果有多个不同的NERDTree(例如NERD_tree_1,NERD_tree_2),做镜像时会提示选择哪一个。
:NERDTreeFind <文件/目录路径>1.光标在编辑窗口时,不加参数,运行命令后NERDTree窗口光标跳转到当前打开的文件处。
2.有参数时,就直接展开指定路径的父节点,同时光标也移动到指定路径的父节点。
3.光标在NERDTree窗口时,不加参数,运行命令后根节点跳转到终端路径的上一级,并展开这个路径节点(比如执行vim时,终端的当前路径为/home/sun/,那么执行NERDTreeFind后,根节点就变成了/home/,并且/home/sun/节点会展开)。
:NERDTreeFromBookmark <书签名称> 启动一个新的NERDTree,根节点初始化为书签路径。
:NERDTreeRefreshRoot刷新NERDTree根节点。

在这里插入图片描述

(4) 标签页

快捷键作用
t光标在nerdtree上的文件时,按 t 会新建标签来显示该文件,并且会跳转到新标签页。
T光标在nerdtree上的文件时,按 T 会新建标签来显示该文件,但不会跳转到新标签页。
gt向后切换标签页,不方便使用
gT向前切换标签页,不方便使用
:tabp向前切换标签页,建议在.vimrc中创建快捷键,方便使用
:tabn向后切换标签页,建议在.vimrc中创建快捷键,方便使用
:tabnew <文件路径>新建标签页,并在新标签页上打开指定文件
:tabc关闭当前标签页
:tabo关闭其他所有标签页
:tabs查看所有标签页

在这里插入图片描述

(5) 书签
以下命令只在NERDTree窗口中有效,书签适用于文件和目录。

快捷键作用
B在NERDTree中显示书签列表,该列表支持 o,t,i 等文件打开操作。
:Bookmark <书签名称>给光标处的文件或目录创建书签,注意书签名不要有空格。
:BookmarkToRoot <目录书签名称>将NERDTree根节点变更为指定目录书签的路径。
:RevealBookmark <书签名称>在NERDTree中展开此书签。

注:
1.如果此书签文件已经在NERDTree中被展开,则此命令可以直接将光标跳转到该标签文件上。
2.书签必须在当前根节点路径里才可使用此命令。
:OpenBookmark <书签名称>如果是文件书签,则直接在编辑窗口打开该文件,NERDTree窗口不变。
如果是目录书签,则NERDTree窗口根节点变更为该目录,编辑窗口不变。

注: 不同于RevealBookmark,书签不在当前目录下时,也可以使用。
:EditBookmarks打开~/.NERDTreeBookmarks文件,此文件是记录书签的文件。

注:
1.在~/.NERDTreeBookmarks中添加或删除书签后,需要使用ReadBookmarks命令重新读取,才可以生效。
2.即使运行ReadBookmarks后,NERDTree中书签显示也没有变化,需要使用NERDTree命令重新创建实例才能刷新。
:ReadBookmarks重新读取~/.NERDTreeBookmarks书签文件,使其生效。

此命令有bug,见下面动图,删除的build-aux书签名称还留在NERDTree中。不光如此,书签文件中添加的书签也无法反馈到NERDTree窗口。
解决方法:执行NERDTreeRefreshRoot命令刷新一下根节点。
:WriteBookmarks将书签写入文件~/.NERDTreeBookmarks,不过实测发现用不上这个命令,创建书签后会自动写入书签文件。
:ClearBookmarks <书签名称>清除指定书签;如果光标在目标书签上时,也可以不用加参数。
:ClearAllBookmarks清除所有标签。

此命令有bug,见下面动图,清除书签后,NERDTree中还留有书签名字。
解决方法:执行NERDTreeRefreshRoot命令刷新一下根节点。

在这里插入图片描述

3.2 Tagbar — 代码结构

就是用来显示文件结构的插件,如下图。我看了一下,c,c++,java文件都是支持的。
在这里插入图片描述

1. Tagbar基本配置
下面是我在~/.vimrc中的配置,请依据自己情况进行配置。

Plug 'majutsushi/tagbar'      " 放在语句 call plug#begin() 和 call plug#end() 之间

" tagbar
map <F4> :TagbarToggle<CR>      " 按键F4:Tagbar窗口的收缩/展开

2. 安装
打开vim编辑器,在末行模式下输入命令PlugInstall后回车,等待安装完成即可。

3. 快捷键
Tagbar的用法较为简单,所以快捷键就不过多讲解了。原生的快捷键我用着不是很方便,改了三个,如下图,改完后重启Vim生效。
在这里插入图片描述

3.3 vim-airline — 状态栏美化

在这里插入图片描述

1. vim-airline基本配置

" 放在语句 call plug#begin() 和 call plug#end() 之间
Plug 'vim-airline/vim-airline'
Plug 'vim-airline/vim-airline-themes'

" vim-airline
let g:airline_theme='bubblegum'         " 配置主题。如果不配置,默认主题也挺不错的,如上面图所示。

2. 安装vim-airline
打开vim编辑器,在末行模式下输入命令PlugInstall后回车,等待安装完成即可。

3. 扩展主题安装
vim-airline中默认只有一个dark主题,可以去github上下载更多主题文件,然后放到~/.vim/plugged/vim-airline-themes/autoload/airline/themes中,这样我们就可以配置更多主题了。

主题文件地址(国内镜像地址):https://hub.yzuu.cf/vim-airline/vim-airline-themes
在这里插入图片描述

更换主题方法:
(1) 临时方法:Vim末行模式下,执行命令AirlineTheme <主题名称>(例如:AirlineTheme lucius)
(2) 永久方法:在.vimrc文件中添加语句let g:airline_theme=<主题名称>(例如:let g:airline_theme=lucius)

我自己试了几个,如下图所示。
在这里插入图片描述

3.4 FZF — 模糊搜索神器

FZF(Fuzzy Finder)是一款功能强大的模糊搜索神器,可以和很多例如git,find,vim,ag,ranger,ps等等一系列实用性工具结合。掌握FZF无疑是提高工作效率最重要的手段之一。本篇文章因为是讲Vim的,所以这里只讲解在Vim中的FZF使用。

1. 在.vimrc中的基本配置
FZF的作者为了方便大家使用,做了一个FZF的Vim插件 ( fzf.vim ),只需要简单配置一下就可以安装。

" 执行PlugInstall时克隆fzf源码到本地,并且会执行fzf中的install程序来安装fzf。
Plug 'junegunn/fzf', { 'do': { -> fzf#install() } }

" 执行PlugInstall时下载fzf.vim插件
Plug 'junegunn/fzf.vim'

注:上面的install程序会从github上下载一些东西,如果你的网络访问github比较费劲,这里可以先不写逗号及后面的部分。等到PlugInstall完成后,再把这部分加上,然后修改~/.vim/plugged/fzf/install文件,将github地址修改为国内镜像地址。等到用fzf的时候会提示进行安装。
在这里插入图片描述

2. 安装
(1) 打开vim编辑器,在末行模式下输入命令PlugInstall后回车,等待安装完成即可。
(2) 在vim中打开fzf,第一次会提示安装fzf程序,点击y回车后等待安装完成即可。这一步可以参考下面的gif动图,其中的Files命令是fzf中用来查找文件的,可以看到很迅速的就找到了framework中的Camera.java文件。
在这里插入图片描述

3. FZF在vim中的常用命令

CommandList
:Files [PATH]Files (runs $FZF_DEFAULT_COMMAND if defined)
:GFiles [OPTS]Git files (git ls-files)
:GFiles?Git files (git status)
:BuffersOpen buffers
:ColorsColor schemes
:Ag [PATTERN]ag search result (ALT-A to select all, ALT-D to deselect all)
:Rg [PATTERN]rg search result (ALT-A to select all, ALT-D to deselect all)
:RG [PATTERN]rg search result; relaunch ripgrep on every keystroke
:Lines [QUERY]Lines in loaded buffers
:BLines [QUERY]Lines in the current buffer
:Tags [QUERY]Tags in the project (ctags -R)
:BTags [QUERY]Tags in the current buffer
:ChangesChangelist across all open buffers
:MarksMarks
:JumpsJumps
:WindowsWindows
:Locate PATTERNlocate command output
:Historyv:oldfiles and open buffers
:History:Command history
:History/Search history
:SnippetsSnippets (UltiSnips)
:Commits [LOG_OPTS]Git commits (requires fugitive.vim)
:BCommits [LOG_OPTS]Git commits for the current buffer; visual-select lines to track changes in the range
:CommandsCommands
:MapsNormal mode mappings
:HelptagsHelp tags 1
:FiletypesFile types

3.5 NERDCommenter — 代码注释插件

类似IDE软件上的一键多行注释 / 取消注释的功能。
ps:下面的示例中,空格键就是leader键,我在.vimrc文件中,把leader键映射成空格了。

在这里插入图片描述
1. NERDCommenter基本配置

Plug 'scrooloose/nerdcommenter'      " 放在语句 call plug#begin() 和 call plug#end() 之间

2. 安装NERDCommenter
打开vim编辑器,在末行模式下输入命令PlugInstall后回车,等待安装完成即可。

3. 常用快捷键

快捷键作用
[count]<leader>cc注释当前行或者可视模式下选中的内容
[count]<leader>cn与[count]<leader>cc一样。文档上说cn可以嵌套注释,而cc不能,但是我实际使用这俩是一样的,可能这版有bug。
[count]<leader>c<space>切换注释状态。已经注释的代码会取消注释,未注释的代码会进行注释。
[count]<leader>cm与上面不同的是,使用一组符号进行注释选定内容。以C代码举例,如下:

1.使用上面几个快捷键:
 /*int a = 1;*/
 /*int b = 2;*/

2.使用cm快捷键:
 /*int a = 1;
 int b = 2;*/
[count]<leader>cA在当前行末尾追加注释符号,并将光标跳转到注释符号后。只适用普通模式,也就是说不支持多行操作。
[count]<leader>cu取消注释。

3.6 vim-surround — 包裹符号

这个插件可以很方便的变更,添加,删除包裹语句的符号。这里的符号是广义的,除了是个单独的符号外,也可以是个字符串。
在这里插入图片描述

1. vim-surround基本配置

Plug 'tpope/vim-surround'      " 放在语句 call plug#begin() 和 call plug#end() 之间

2. 安装vim-surround
打开vim编辑器,在末行模式下输入命令PlugInstall后回车,等待安装完成即可。

3. 用法
vim-surround中有几个文本符号代表一些包裹符号,文本符号和包裹符号都可以使用,对应关系如下:

文本符号包裹符号说明
b()执行添加或变符号命令时,若使用的是左括号,则会自动添加空格,而右括号不会。
B{}执行添加或变符号命令时,若使用的是左括号,则会自动添加空格,而右括号不会。
r[]执行添加或变符号命令时,若使用的是左括号,则会自动添加空格,而右括号不会。
a<>如果想添加尖括号,需要使用"a"或者右尖括号">"。
t代表html标签如果想添加标签,可以使用 “t” 或者左尖括号 “<”

3.1 普通模式:
注:下面表格原文本列的红色部分代表光标所在位置,原文本没有标注红色则代表当前情况下不受光标位置影响。

cs — 替换原有包裹符号
基本语法:cs<原符号><替换符号>
前提条件:光标需要在一对原符号之间或者在原符号上。

原文本命令新文本说明
“Hello world!”cs"’‘Hello world!’把双引号换成单引号
“Hello world!”cs"<q><q>Hello world!</q>把双引号换成<q>
(123+456)/2cs)][123+456]/2把()换成[],不添加空格。注:所有的右括号都是不添加空格的。
(123+456)/2cs)[[ 123+456 ]/2把()换成[],添加空格。注:所有的左括号都是添加空格的。
<div>Yo!</div>cst<p><p>Yo!</p>t 指的就是table标签,所以这里是将原有标签换成<p></p>。

ps:任何<xxx></xxx>形式的文本在这里都可以当成标签。

ys和yss — 添加包裹符号

(1) ys为范围内的字符串添加包裹符号
基本语法:ys<指代范围的快捷键><要添加的符号>
指代范围的快捷键:如vim中常用的iw(单词),aw(单词及一个空格)等。

(2) yss为整行语句添加包裹符号
基本语法2:yss<要添加的符号>

原文本命令新文本说明
Hello world!ysiw)Hello (world)!为光标所在单词(world)添加包裹符号(这里指定为小括号了)。

注:ys可以理解为 you surround,i 这里理解为insert插入,w理解为word单词。
Hello world!yssB{Hello world!}为整行添加包裹符号(这里指定为大括号了)。

注:B代表大括号,b代表小括号,当然也可以使用符号表示,如 (,{ 等。

ds — 删除包裹符号
基本语法:ds<要删除的符号>

原文本命令新文本说明
“Hello world!”ds"Hello world!删除双引号
(123+456)/2ds)123+456/2删除小括号
<div>Yo!</div>dstYo!删除table标签

自定义包裹符号
可以为某个符号自定义内容,需要在.vimrc中定义变量surround_<符号对应的ascii码值>,例如变量surround_45代表符号"-",定义形式类似赋值操作,如下所示:

surround_<符号对应的ascii码值> = "开头的包裹符号\r结尾的包裹符号"

注:
(1) 一般情况下,\r代表被包裹的语句,其左侧为开头包裹符号,右侧为结尾的包裹符号。此外,也可以将两个\r放在一对\1等特殊变量中间,来做匹配并替换字符串操作,下面会较为详细介绍这个功能。
(2) vim的末行模式下,查询符号对应的ascii码:echo char2nr(“符号”)。查询ascii码对应的符号:echo nr2char(ascii码值)

(1) 普通用法:
首先,在.vimrc中定义变量surround_45(对应符号"-")。

autocmd FileType php let b:surround_45 = "<?php \r ?>"

注:
(1) autocmd FileType php 这句规定了后面的变量只是在php文件中有效。
(2) \r左边部分就是开头的包裹符号,右边部分就是结尾的包裹符号。
原文本命令新文本
print “Hello *world!”yss-<?php print "Hello world!" ?>

在这里插入图片描述


(2) 特殊变量\1…\6的用法:
这几个变量可以用来接收用户输入的内容,需要成对使用,例如\1\1,\2\2等。一对特殊变量代表一次输入,两对不同的特殊变量,则会要求输入两次,以此类推。

  • 一对特殊变量的中间可以添加提示信息,如\1please input keyword:\1,在执行 yss<符号> 命令后,会在末行中显示这个提示信息,但是最后这个提示信息是不会添加到包裹符号中的,仅仅只是提示作用。
  • 一对特殊变量的中间可以使用\r元字符\r替换字符进行匹配并替换字符串,如\1\rabc\rdef\1,在特殊变量接收到输入的字符串后,会执行字符串匹配替换操作。例如输入的字符串为"abc123",则最后得出的字符串为"def123"。
  • 一对特殊变量的前或后的字符串会被添加到包裹符号中,例如surround_108的定义体为 “begin \1please input keyword:\1 end” ,输入字符串为"testkey",则最后得出的字符串为"begin testkey end"。

例一:.vimrc中定义如下surround变量。

" 符号l(小写L)
let g:surround_108 = "\\begin{\1please input keyword: \1}\r\\end{\1\1}"

在这里插入图片描述

执行一下看看效果:
在这里插入图片描述

例二:.vimrc中定义如下surround变量。

" 符号p
let g:surround_112 = "\\begin{\1keyword1: \1, \2keyword2: \2}\r\\end{\3keyword3\3}"

在这里插入图片描述

执行一下看看效果:
在这里插入图片描述

例三:.vimrc中定义如下surround变量。

" 符号t
let g:surround_116 = "\\begin{\1please input keyword: \1}\r\\end{\1\rabc\rdef\1}"

在这里插入图片描述

执行一下看看效果:
在这里插入图片描述

例四:.vimrc中定义如下surround变量。

" 符号d
let g:surround_{char2nr("d")} = "<div\1id: \r..*\r id=\"&\"\1>\r</div>"

在这里插入图片描述

执行一下看看效果:
在这里插入图片描述

再补充说明一下:

  • 上面的图片中我做了说明,本例中匹配的字符串是一个或一个以上的非换行字符。正常也等价于 .+,但实际验证时发现此插件不识别这种正则表达式。
  • 动图中做了三种演示情况:
    第一次没有输入字符串直接回车,匹配失败,得到的包裹符号为<div></div>,符合预期;
    第二次输入一个字符1,匹配成功,得到的包裹符号为<div id=“1”></div>,符合预期;
    第三次输入两个字符12,匹配成功,得到的包裹符号为<div id=“12”></div>,符合预期。

3.2 可视模式:
下面表格原文本列的红色部分,代表可视模式下光标所选中的字符串。
(1) 添加包裹符号

原文本命令新文本说明
print “Hello world!”S(print “( Hel )lo world!”添加带空格的小括号,这个命令和普通模式下的ys一样。
print “Hello world!”gS(print “(
  Hel
)lo world!”
和S(比,多了换行和缩进

(2) 替换包裹符号
在可视模式下选择好要替换符号所在行后,然后按冒号进行批量处理命令 norm f<cs<"

  • norm ( 也可写normal ) 也就是vim的普通模式;
  • f< 代表查找左尖括号并将光标跳转到找到的目标位置;
  • cs<"就是上面讲的包裹符号替换的命令,将尖括号替换为双引号。

在这里插入图片描述

3.3 插入模式:
下面表格原文本列的红色部分,代表光标所在位置。

原文本命令新文本说明
print “Hello world!”<ctrl> + g + sbprint “H()ello world!”添加小括号
print “Hello world!”<ctrl> + g +Sbprint “H(
    <光标>
  )ello world!”
和 <ctrl> + g + sb 比,多了换行和缩进

vim-surround的文档上,还有一种插入模式下的用法。在.vimrc中定义变量surround_insert_tail,插入包裹符号后,会在其后追加surround_insert_tail变量的内容,变量定义如下所示:

let g:surround_insert_tail = "<++>"

个人感觉插入模式下的使用还是有些麻烦,还容易按错。如果只是想在插入模式下快速的打出成对的括号等符号,并将光标自动切换到括号内,可以直接在 .vimrc 文件中做按键映射,如下:

inoremap ( ()<Left>
inoremap [ []<Left>
inoremap < <><Left>
inoremap } {}<Left>
inoremap { {}<Left><CR><CR><Up><Tab>
inoremap " ""<Left>
inoremap ' ''<Left>

在这里插入图片描述

3.7 Tabular — 符号对齐

1. Tabular基本配置

Plug 'godlygeek/tabular'      " 放在语句 call plug#begin() 和 call plug#end() 之间

2. 安装Tabular
打开vim编辑器,在末行模式下输入命令PlugInstall后回车,等待安装完成即可。

3. 用法
3.1 正常用法:
Tabular的用法比较简单,首先选中需要对齐的行,然后末行模式下输入Tabularize /<符号> 后回车即可。
在这里插入图片描述

3.2 扩展用法:
从上面的动图可以看到,Tabular默认会对齐符号右侧的文本,并且符号与两侧的文本间距为一个空格。那么下面来讲一下如何自定义对齐方式和间距。
对齐方式:可以使用选项 l (小写L),r,c 来规定对齐方式。l 代表左对齐,r 代表右对齐,c 代表中间对齐。注意这个对齐是以要对齐的符号为参照物的,看下面的例子就明白了。

原版内容如下:
在这里插入图片描述

例1:
命令:Tabularize /=/r1
解释: r 就是右对齐,可以看到符号左边的部分相对 “=” 已经右对齐了,r 后边的1则代表对齐后符号两边追加的空格数为1。
在这里插入图片描述

例2:
命令:Tabularize /=/l1
解释: l 就是左对齐,可以看到符号右边的部分相对 “=” 已经左对齐了,l 后边的1则代表对齐后符号两边追加的空格数为1。
在这里插入图片描述

例3:
命令:Tabularize /=/r1c1l0
解释: 这个命令是作者文档上给的例子,可以让符号两边的文本都相对符号做对齐操作。这个命令我建议记住就可以了,深究起来比较麻烦,有点摸不清作者的逻辑。
在这里插入图片描述

除了上面的使用方法,作者在文档 ( ~/.vim/plugged/tabular/doc ) 中还介绍了一些多符号的对齐用法,以及一些结合正则表达式的用法等。感兴趣的同学可以自行研究,不过,我倒是觉得这些用法有点过于麻烦了,有点失去了安装插件的意义。。。

3.8 vim-illuminate — 突出显示光标所在单词

1. vim-illuminate基本配置

Plug 'rrethy/vim-illuminate'      " 放在语句 call plug#begin() 和 call plug#end() 之间

2. 安装vim-illuminate
打开vim编辑器,在末行模式下输入命令PlugInstall后回车,等待安装完成即可。

3. 用法
安装好插件后,用vim打开文件,就可以看到光标所在单词都会突出显示。突出显示方式有两种,如下所示:

(1) 下划线突出显示(默认)
在这里插入图片描述

(2) 高亮突出显示
在这里插入图片描述

想要达到这种效果,需要在~/.vimrc中添加下面语句。

hi illuminatedWord ctermfg=white ctermbg=161

hi: 用于定义高亮组样式
illuminatedWord: 这个是vim-illuminate插件的关键字,高亮组名称
ctermfg: 终端前景颜色,使用ANSI颜色代号(0-255)或者常规颜色单词。
ctermbg: 终端背景颜色,使用ANSI颜色代号(0-255)或者常规颜色单词。

可以使用下面代码输出256种ANSI颜色。

#!/bin/bash                                                                                                                                                                                                 

count=0
for i in {0..255}; do
|   printf "\033[48;5;${i}m%7d\033[0m" ${i}
|   ((count++))
|   if [ $((count % 16)) -eq 0 ]; then
|   |   printf "\n"
|   fi
done

在这里插入图片描述

;