EasyAlign
EasyAlign 是一款用来做字符对齐的插件,简直是强迫症患者的福音。
项目地址
https://github.com/junegunn/vim-easy-align
安装
修改
.vimrc
配置,在call plug#begin()
后面添加如下配置
注意:Vim 插件管理器的使用请参考plugin.md
运行 Vim 并执行命令
:PlugInstall
, 可能会得到如下提示:
使用
配置
添加
.vimrc
配置如下:
实验
在下面的代码中尝试如下操作:
首先定位光标到上面代码中的任意一句,按
gaip<Space>
,应该会得到 如下结果
保持光标不动,按
gaip=
,应该会得到如下结果
保持光标不动,按
u
,再按gaip*=
,应该会得到如下结果
下面解释一下按键的意思:
gaip
ga
是开启 EasyAlign 的快捷键,我们在.vimrc
配置文件中定义的ip
是定义操作区域,可以用任意选择操作命令完成,ip
是选择当前段落,如果光 标在代码第一行,则可以用2j
代替ip
此时命令区域会出现
:EasyAlign (_)
字样,表示等待匹配输入按下
<Space>
是要将第一个空格前后对齐
gaip=
意义同上,
=
即将<等号>
前后对齐
gaip*=
为了看到更明显的效果,先用
u
撤销了前面的操作=
前面的*
是一个描述符,可以是数字,代表第几个等号,也可以是负数,代表 倒数第几个,也可以是星号,代表所有。
如果确定修改好了上面提到的配置,你还可以尝试
gaip/
来对齐注释部分,执行后看 上去会像下面这样
匹配符说明
上面提到的 <Space>
=
都是 EasyAlign 中定义好的特殊符号,用来表示某一类特征符 ,具体可以参考下表:
按键 | 使用场景说明 |
---|---|
| 匹配空白符 |
| 包含等号的操作符( |
| 应用于 JSON 或 YAML 格式 |
| 应用于多行点语法调用 |
| 应用于多行参数列表 |
| 对 LaTeX table 进行格式化,匹配 |
| 应用于对 Ruby/Python 的注释的对齐 |
| Markdown 表格 |
注意:上表中提到的 <Bar>
键即 |
键
尝试在上表中按
gaip*|
对 markdown 表格进行对齐
Tips
对齐方式
在等待输入匹配符,命令区出现 :EasyAlign (_)
字样时,可以按 <Enter>
键选择对 齐方向,按一次切换为右对齐,显示 :EasyAlign[R] (_)
,再按一次切换为居中对齐,显 示为 :EasyAlign[C] (_)
,再按切换回默认的左对齐,显示也恢复原样。
在上面的 markdown 表格中尝试一下
gaip<Enter><Enter>*|
正则匹配
在等待输入匹配符时,按快捷键 <Ctrl-x>
进入匹配模式,此时输入你需要的匹配特征正 则即可匹配特殊组合。参考下面的文字:
尝试输入
gaip*<Ctrl-x>
,此时进入正则匹配模式,继续输入<[-=~]*<Enter>
会得 到如下所示结果。
更多参考
更多内容请参考项目页的介绍
Last updated