用 Vim 来打造自己心仪的 IDE

2015-11-10 14:19:34 +08:00
 tiange

一年前我从 Vim 切换到了 WebStorm ,是因为 WebStorm 强大的重构功能,以及 Super Search 功能。在开发天码营前端的过程中,涉及多文件编辑和重构时 WebStorm 的优势便非常明显。

最近到手了 HHKB ,从键盘到触摸板的切换还是挺麻烦的,于是 Vim 编辑的需求又来了。。加之 WebStorm 经常假死,我决定重新启用 Vim 。同时重新打造了我的 Vim ,使它能够满足我在 IDE 中的所有需求。这篇文章便来记述整个过程,或许有些帮助。先上图:

上图中,下面的 Console 是通过 Tmux 搞的。 Tmux 的配置和使用参见:优雅地使用命令行: Tmux 终端复用

准备工作

安装 Git 、 Homebrew (如果你是 Mac ),并安装新版本的 Vim(>=7.3)。一般 linux 发行版都会预装 Vim ,你需要检查一下 vim 的版本:

$ vim --version
VIM - Vi IMproved 7.4 (2013 Aug 10, compiled Jul  4 2015 01:13:13)
MacOS X (unix) version
Included patches: 1-712
Compiled by Homebrew

如果上述命令失败,那么你需要安装一个 Vim~ 这里提供了 Vim 的基本快捷键备忘录。

OSX

$ brew update
$ brew install vim

Linux

apt-get install vim   # ubuntu
pacman -S vim         # archlinux
yum install vim       # centos

Vundle

Vundle是基于 Git 的 vim 插件管理工具,是目前最推荐的工具。之前我的.vim下手动维护着各种插件,目录结构看起来是这样的:

|- doc/
|  |- emmet.txt
|  |- NERDCommenter.txt
|  |- ...
|- plugin/
|  |- emmet.vim
|  |- NERDCommenter.vim
|  |- ...
|- autoload/
|  |- emmet.vim
|  |- NERDCommenter.vim
|  |- ...
|- ftplugin/

使用 Vundle 后变成了这样:

|- bundle/
|  |- emmet/
|  |  |- doc/
|  |  |- autoload/
|  |- NERDCommenter/
|  |  |- doc/
|  |  |- autoload/
|- ftplugin/

其中ftplugin里面是我的配置,比如编译运行的快捷键等。另外,如果你在用 Git 同步 Vim 配置的话,可以把bundle/加入.gitignore

那么怎么安装 Vundle 呢?

git clone https://github.com/gmarik/Vundle.vim.git ~/.vim/bundle/Vundle.vim

然后在你的.vimrc中加入 Vundle 的配置:

set nocompatible              " required
filetype off                  " required

set rtp+=~/.vim/bundle/Vundle.vim
call vundle#begin()
Plugin 'gmarik/Vundle.vim'
call vundle#end()            " required
filetype plugin indent on    " required

然后在 vim 中运行:PluginInstall即可(或者在 Bash 中运行vim +PluginInstall)。以后只需要在添加一行Plugin 'xxx'并运行:PluginInstall即可自动安装插件。

窗格管理

要把 Vim 打造成一个 IDE ,你需要熟悉 Vim 如何创建窗格,以及如何在窗格间切换。 :sp可以水平分割当前窗格,:vs可以垂直分割当前窗格。可以重复多次,创建复杂的窗格布局:

C-w, C-w可以切换到下一窗格,C-w, j切换到下面的窗格,C-w, k切换到上面的窗格,C-w, h切换到左边的窗格,C-w, l切换到右边的窗格。 我为这些操作设置了更加方便的快捷键,比如 Ctrl+J 切换到下面的窗格:

nnoremap <C-J> <C-W><C-J>

多文件管理可以使用多窗格,也可以使用 Buffer 的方式。比如vim a.js b.js就会在 Buffer 中同时打开两个文件。使用:ls列出当前 Buffer 中的文件,然后使用数字键切换。也可以使用:b 2切换到 Buffer 中的第二个文件。

折叠

有些人特喜欢代码折叠,我就在这里列一下如何优雅地折叠代码。首先在.vimrc中添加配置:

set foldmethod=indent
au BufWinLeave * silent mkview  " 保存文件的折叠状态
au BufRead * silent loadview    " 恢复文件的折叠状态
nnoremap <space> za             " 用空格来切换折叠状态

开启以 indent 来折叠代码后,打开一个文件会发现有缩进的内容全被折叠起来了。所以我们引入一个SimpleFold来更智能地折叠:

Plugin 'tmhedberg/SimpylFold'

不要忘了运行:PluginInstall

自动补全

自动补全当然是用YCM

Plugin 'Valloric/YouCompleteMe'

然后进行配置就好了, YCM 是通过 Vim 的omnifunc机制来自动补全的,所以你需要为你想要支持的语言安装一个提供omnifunc接口的 Vim 插件。

我在另一篇博客中有详细介绍了自动补全、语法检查等配置。

项目树

这想必是 IDE 能提供的最大的好处之一,在 Vim 中可以使用NERDTree来显示文件树,它的快捷键非常多,所以和 Vim 一样的越用越爽。

Plugin 'scrooloose/nerdtree'
" 这个插件可以显示文件的 Git 增删状态
Plugin 'Xuyuanp/nerdtree-git-plugin'

这里给出我的一些 NERDTree 配置:

" Ctrl+N 打开 /关闭
map <C-n> :NERDTreeToggle<CR>
" 当不带参数打开 Vim 时自动加载项目树
autocmd StdinReadPre * let s:std_in=1
autocmd VimEnter * if argc() == 0 && !exists("s:std_in") | NERDTree | endif
" 当所有文件关闭时关闭项目树窗格
autocmd bufenter * if (winnr("$") == 1 && exists("b:NERDTreeType") && b:NERDTreeType == "primary") | q | endif
" 不显示这些文件
let NERDTreeIgnore=['\.pyc$', '\~$', 'node_modules'] "ignore files in NERDTree
" 不显示项目树上额外的信息,例如帮助、提示什么的
let NERDTreeMinimalUI=1

全局搜索

WebStrom 的全局搜索是我当初使用它的主要原因;而现在全局搜索总是突然崩溃,也是我放弃 WebStorm 而转到 Vim 的主要原因。

成也萧何败萧何

安装ctrlp

Plugin 'kien/ctrlp.vim'

然后按下C-P,便可以全局搜索啦。使用C-jC-k上下翻页,<Enter>打开选中文件。同样,给出一些有用的配置:

let g:ctrlp_working_path_mode = 'ra'
set wildignore+=*/tmp/*,*/node_modules/*,*.so,*.swp,*.zip     
let g:ctrlp_custom_ignore = {'dir':  '\v[\/]\.(git|hg|svn)$', 'file': '\v\.(exe|so|dll)$'}

剪切板

剪切板想必是所有 Vim 用户的痛。但是!在 Mac 下只需要设置:

set clipboard=unnamed

你在 Vim 中 copy 的所有内容都会上系统剪切板。在 Vim 中拷贝内容时,可以切换到拷贝模式防止自动缩进和补全。 我的快捷键是<F9>

set pastetoggle=<F9>

状态栏

有没有注意到我酷炫的状态栏?安装一个powerline

Plugin 'Lokaltog/powerline', {'rtp': 'powerline/bindings/vim/'}

此外,为了正确显示 Powerline 的图标,还需要一些设置:

set guifont=Inconsolata\ for\ Powerline:h15
let g:Powerline_symbols = 'fancy'
set encoding=utf-8
set t_Co=256
set fillchars+=stl:\ ,stlnc:\
set term=xterm-256color
set termencoding=utf-8

然后在系统字体库中导入powerline font,如果是 Mac 的话可以使用 Font Book 来导入。 然后需要设置 terminal ( iTerm )的 non-ASCII 字体为 PowerlineSymboles :

注释、反注释

NERDCommenter是个不错的工具,支持非常多的语言:

Plugin 'scrooloose/nerdcommenter'   " commenter: \cc \cu

然后按下\cc来注释当前航,\cu来反注释,\c<space>来切换注释。其中的\\是可以设置的:

let mapleader=';'

Loremipsum

哈哈如果你没见过标题中的这个词就可以跳过了。前端开发中通常需要添加一些占位符来让页面看起来有内容又像人话, loremipsum (拉丁语)通常就是这些占位符的起始字符。比如下面一段:

Sodales eget, leo. Sed ligula augue, cursus et, posuere non, mollis sit
amet, est. Mauris massa. Proin hendrerit massa. Phasellus eu purus. Donec est
neque, dignissim a, eleifend vitae, lobortis ut.

安装一个loremipsum即可:

Plugin 'vim-scripts/loremipsum'

我还加了点设置来方便控制长度:

inoremap Lorem <Esc><Esc>:Loremipsum 20<CR>
inoremap Ipsum <Esc><Esc>:Loremipsum 70<CR>

这样,当输入Lorem时产生长度为 20 单词的占位符,输入Ipsum时产生长度为 70 的占位符。
参考链接:

原文出自我自己的博客,喜欢前端开发、 Linux 和 Vim 的 V 友欢迎访问我天码营主页

20271 次点击
所在节点    Vim
94 条回复
183553404
2015-11-10 14:58:52 +08:00
个人认为 vim 和 Emacs 是计算机系统中最强大的两个编辑器,看了下楼主的主页,原来是 Linux 极客,难怪会用 HHKB .
az402
2015-11-10 16:29:15 +08:00
kingddc314
2015-11-10 16:30:06 +08:00
试试跳转插件: easymotion/vim-easymotion
az402
2015-11-10 16:30:18 +08:00
@tiange http://tianmaying.com/course/web-development
『为什么选择加入天马营?』
是个错别字吧
vitovan
2015-11-10 16:32:27 +08:00
Emacs 党撇着嘴走过~
kassadin
2015-11-10 16:38:52 +08:00
累不累
fising
2015-11-10 16:40:04 +08:00
累不累
fising
2015-11-10 16:40:12 +08:00
累 不 累
fhefh
2015-11-10 16:40:29 +08:00
mark 下~~~
root787
2015-11-10 16:40:47 +08:00
@kassadin 累不累+ 1
chemzqm
2015-11-10 16:44:11 +08:00
缺少一个 IDE 最牛逼的东西 智能感知 http://segmentfault.com/a/1190000003887409
doomgiant
2015-11-10 16:45:01 +08:00
觉得 VIM 配置麻烦,所以一直只是用来快速查看

不过 lz 想得详细,赞一个
iamleung
2015-11-10 16:52:34 +08:00
收藏了
chemzqm
2015-11-10 16:54:41 +08:00
其实 VIM 的插件都是些锦上添花的东西,最重要还是熟练掌握 VIM 中快速移动的技巧,所以我不得不推荐 https://github.com/wikitopian/hardmode
bigcoon
2015-11-10 16:59:01 +08:00
累 不 累
matrix67
2015-11-10 17:03:02 +08:00
用法错误, vim 大神讲究不用插件写代码,高亮都不开,逃
arfaWong
2015-11-10 17:07:55 +08:00
@kassadin 累不累 +10086
@fising 看到你的头像有点累
jswh
2015-11-10 17:27:31 +08:00
Vim 没有好的 php 补全引擎,所以尝试了一段时间还是用回了 PHPstorm
congeec
2015-11-10 17:58:34 +08:00
kmahyyg
2015-11-10 18:00:32 +08:00
好帖

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/235055

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX